/*-------------------------------------------------------*/
/*寻找和为定值的两个数
输入一个数组A[0,N-1]和一个数字Sum,在数组中查找
两个数Ai,Aj,是真的Ai+Aj=Sum*/
/*解法一:暴力求解*/
/*解法二:一个数组两头扫*/ void TwoSum(int data[],unsigned int length, int sum){
//sort(data,data+length) 如果数组是有序的,那就事先排好序O(NlonN)
int begin=;
int end=;ength-;
while(begin<end){
long currSum=data[begin]+data[end];
if(currSum==sum){
printf("%d %d\n",data[begin],data[end]);
//如果需要所有满足条件的数组对,则需要加上下面两条语句
//begin++;
//end--;
break;
}
else{
if(currSum<sum) begin++;
else end--;
}
}
}
/*-------------------------------------------------------*/
/*寻找何为定值的m个数(不考虑存在负数的情况)*/
/*已知数组A[0...N-1],给定某数值sum,找出数组中的若干个数,
使得这些数的和为sum*/
int a[]={,,,,};
int size=sizeof(a)/sizeof(int);
int sum=;//sum为计算的和 //x[]为最终解,x与a下标对应.i为考察x[i]是否加入,has表示当前的和
void EnumNumber(bool* x,int i,int has){
if(i>=size) return ;
if(has+a[i]==sum){//如果当前的和加上a[i]满足sum
x[i]=true;//代表a[i]要输出
Print(x);//这个打印函数没写,自己可以加上去
x[i]=false;//改为false,准备下一轮
} x[i]=true;
EnumNumber(x,i+,has+a[i]); x[i]=false;
EnumNumber(x,i+,has);
} int main(){
bool* x=new bool[size];
memset(x,,size);
EnumNumber(x,,);
delete[] x;
return ;
}
/*考虑负数的情况*/
/*
可对整个数组A[0...N-1]进行正负排序,使得负数都在前面,正数都在后面
使用剩余正数的和作为分支限定的约束
如果A[i]为负数,全部正整数都算上还不够,就不能选A[i]
如果递归进入了正数范围,按照数组是全正数的情况正常处理*/

在数组中寻找和为定值的n个数的更多相关文章

  1. 【Data Structure & Algorithm】在排序数组中查找和为定值的两个数

    在排序数组中查找和为定值的两个数 题目:输入一个已经按升序排序过的数组和一个数字,在数组中查找两个数,使得它们的和正好是输入的那个数字,要求时间复杂度是O(n).如果有多对数字的和等于输入的数字,输出 ...

  2. (1)Two Sum--求数组中相加为指定值的两个数

    Given an array of integers, find two numbers such that they add up to a specific target number. The ...

  3. 【跟着子迟品 underscore】如何优雅地写一个『在数组中寻找指定元素』的方法

    Why underscore (觉得这部分眼熟的可以直接跳到下一段了...) 最近开始看 underscore.js 源码,并将 underscore.js 源码解读 放在了我的 2016 计划中. ...

  4. Coursera Algorithms week3 快速排序 练习测验: Selection in two sorted arrays(从两个有序数组中寻找第K大元素)

    题目原文 Selection in two sorted arrays. Given two sorted arrays a[] and b[], of sizes n1 and n2, respec ...

  5. js数组去重 数组拼接 替换数组中的指定值 递归数组 判断数组中是否存在指定值 数组求和 根据条件判数组值

    这是学习过程中记录的一些关于数组操作的常用属性或方法,记录一下方便以后使用. // 数组去重 var arr1 = [1,1,2,3,4,5,6,3,2,4,5,'a','b','c','a',6,7 ...

  6. 在数组中寻找出现次数大于N/K的数

    给定一个int[]数组,给定一个整数k,打印所有出现次数大于N/k的数,没有的话,给出提示信息. === 核心思想:一次在数组中删除K个不同的数,不停的删除,直到剩下的数的种类不足K就停止删除,那么如 ...

  7. Java实现找出数组中重复次数最多的元素以及个数

    /**数组中元素重复最多的数 * @param array * @author shaobn * @param array */ public static void getMethod_4(int[ ...

  8. 算法笔记_041:寻找和为定值的多个数(Java)

    目录 1 问题描述 2 解决方案 1 问题描述 输入两个整数n和sum,要求从数列1,2,3,...,n中随意取出几个数,使得它们的和等于sum,请将其中所有可能的组合列出来. 2 解决方案 上述问题 ...

  9. 算法笔记_037:寻找和为定值的两个数(Java)

    目录 1 问题描述 2 解决方案 2.1 排序夹逼法   1 问题描述 输入一个整数数组和一个整数,在数组中查找两个数,满足他们的和正好是输入的那个整数.如果有多对数的和等于输入的整数,输出任意一对即 ...

随机推荐

  1. Neo4j(一)

    01-windows下载与安装neo4j https://blog.csdn.net/qq_21383435/article/details/78807024 neo4j的配置文件(图文详解) htt ...

  2. 【NIO】Java NIO之通道

    一.前言 前面学习了缓冲区的相关知识点,接下来学习通道. 二.通道 2.1 层次结构图 对于通道的类层次结构如下图所示. 其中,Channel是所有类的父类,其定义了通道的基本操作.从 Channel ...

  3. 【ML】Predict and Constrain: Modeling Cardinality in Deep Structured Prediction -预测和约束:在深度结构化预测中建模基数

    [论文标题]Predict and Constrain: Modeling Cardinality in Deep Structured Prediction   (35th-ICML,PMLR) [ ...

  4. Spark2.3 HA集群的分布式安装

    一.下载Spark安装包 1.从官网下载 http://spark.apache.org/downloads.html 2.从微软的镜像站下载 http://mirrors.hust.edu.cn/a ...

  5. [转]Java NIO 系列教程

    Java NIO提供了与标准IO不同的IO工作方式: Channels and Buffers(通道和缓冲区):标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(B ...

  6. Spark 论文篇-大型集群上的快速和通用数据处理架构(中英双语)

    论文内容: 待整理 参考文献: An Architecture for Fast and General Data Processing on Large Clusters. Matei Zahari ...

  7. Kubernetes的ConfigMap解析

    ConfigMap功能在Kubernetes1.2版本的时候就有了,许多应用程序会从配置文件.命令行参数或环境变量中读取配置信息.这些配置信息需要与docker image解耦,你总不能每修改一个配置 ...

  8. C# 给枚举类型增加一个备注特性

    /// <summary> /// 备注特性 /// </summary> public class RemarkAttribute : Attribute { /// < ...

  9. 省市区三级联动——思路、demo、示例

    说明(2017-12-13 11:03:58): 1. 这个功能应该是注册的时候非常.常用的了,不过现在都是微信登录,手机端自动获取位置什么的,可能就网站还用用吧! 2. 这个东西的难点在于统计各地省 ...

  10. [转] BootStrap table增加一列显示序号

    原文地址:https://blog.csdn.net/aboboo5200/article/details/78839208 最近由于项目需要,使用BootStrap table做数据展示,其中要在第 ...