找出一堆整数中两个元素和为指定值的所有组合

简介:

问题描述

5, 5,-7, 5, 9, -1, 5, 1, 9, 4, 6 这堆数中两个数的和为10的组合有:5+5, 9+1, 4+6,如何快速的找出这样的组合?

假定

数组a[]存放元素,数组大小为len_a

指定和为aim

思路一

先排序,low=0(最低位置),up=len_a(最高位置)

  • 当a[low]+a[up]>aim时,hig=high-1
  • 当a[low]+a[up]<aim时,low=low+1
  • 当a[low]+a[up]=aim时,输出a[low]、a[up]

代码:

复制代码
#include <iostream>  
#include <algorithm>  
using namespace std;  
  
void printPairSums(int data[], int size, int sum);  
int main(int argc, char* argv[])  
{  
    int data[] = {1, 5, 9, -1, 4, 6, -2, 3, -8};  
    int size = sizeof(data) / sizeof(data[0]);  
    int i;  
    sort(data, data + size);  
    printPairSums(data, size, 8);  
  
    return 0;  
}  
void printPairSums(int data[], int size, int sum)  
{  
    int first = 0;  
    int last = size -1;  
    int s = 0;  
    while (first < last)  
    {  
        s = data[first] + data[last];  
        if (s == sum)  
        {  
            cout << data[first] << " + " << data[last] << " = " << sum << endl;  
            first++;  
            last--;  
        }  
        else if (s < sum)  
        {  
            first++;  
        }  
        else  
        {  
            last--;  
        }  
    }  
}  
复制代码

 

思路二

位操作(详细解释看http://www.cnblogs.com/kaituorensheng/p/3169570.html

思路:

复制代码
#include <iostream>
#include <algorithm>
using namespace std;
void setBit(char *entry, int nBits)
{
    entry[nBits/8] = entry[nBits/8] | (1 << (nBits%8));
}
void setBit_0(char *entry, int nBits)
{
    entry[nBits/8] = entry[nBits/8] & ~(1 << (nBits%8));
}
int checkBit(char *entry, int nBits) { return entry[nBits/8] & (1 << (nBits%8)); } int main() { int data[] = {5,-7, 9, -1, 1, 9, 4, 6}; int aim = 10; int size = sizeof(data) / sizeof(data[0]); int i, min=data[0], max=data[0]; int num_aim = 0; if(aim % 2 == 0) { for(i=0; i<size; i++) { if (aim / 2 == data[i]) num_aim += 1; } } for(i=1; i<size; i++) { if(data[i] < min) min = data[i]; if(data[i] > max) max = data[i]; } int dis_e = (max-min) / 8 + 1; char entry[dis_e]; for (i=0; i<dis_e; i++) { entry[i] = 0; } int dis = 0 - min; for(i=0; i<size; i++) { setBit(entry, data[i]+dis); } if(aim % 2==0) { setBit_0(entry, aim/2 + dis); if(num_aim > 1) cout << data[i] << " " << (aim - data[i]) << endl; } for(i=0; i<size; i++) { if(checkBit(entry, aim - data[i] + dis) != 0) { setBit_0(entry, data[i] + dis); setBit_0(entry, aim - data[i] + dis); cout << data[i] << " " << (aim - data[i]) << endl; } } }
复制代码

 

问题扩展

已知两个升序数组,从两个数组中各取一个数值,求使得两个数之和为给定值的所有组合。

问题本质和一位数组一样,一个从一个数组的开始前进,一个从另外一个数组的最后后退。

 






本文转自jihite博客园博客,原文链接:http://www.cnblogs.com/kaituorensheng/p/3171953.html,如需转载请自行联系原作者
相关文章
|
运维 Kubernetes Linux
10分钟搭建Kubernetes容器集群平台(kubeadm)
10分钟搭建Kubernetes容器集群平台(kubeadm)
|
SQL 分布式计算 DataWorks
MaxCompute产品使用合集之在使用odpscmd上传文件时遇到了最后一行列数不对导致上传失败的问题,如何解决
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
API 调度 开发者
深入浅出Python协程:提高并发性能的秘诀
在当今快速发展的互联网时代,软件系统面临着越来越多的并发处理需求。本文将深入探讨Python中的协程(Coroutine)概念,它作为一种轻量级线程,通过优雅地在单个线程内部进行任务切换,实现高效的IO操作。本文不仅将介绍协程的基础知识和工作原理,还会通过实例演示如何在Python项目中应用协程来提高并发性能,最后将对比协程与传统多线程、多进程模型的优缺点,帮助读者更好地理解协程在现代编程中的重要性。
229 30
TCA - 相关考点脑图
TCA - 相关考点脑图
72 0
|
分布式数据库 Hbase
《HBase实践之MOB使用指南(未翻译)》电子版地址
HBase实践之MOB使用指南(未翻译)
81 0
《HBase实践之MOB使用指南(未翻译)》电子版地址
|
JavaScript 前端开发
【译】JavaScript框架的"代价"
【译】JavaScript框架的"代价"
256 0
【译】JavaScript框架的"代价"
|
JSON Cloud Native Java
【云原生】nacos与springboot结合
【云原生】nacos与springboot结合
|
Linux 调度 虚拟化
进程和计划任务管理
1、查看进程 2、控制进程 3、at一次性任务设置 4、crontab周期性任务设置
进程和计划任务管理
|
存储 SQL 关系型数据库
InnoDB数据页什么时候合并(1)
InnoDB数据页什么时候合并
121 0
|
SQL Oracle 关系型数据库