在数组中寻找和为定值的n个数
/*-------------------------------------------------------*/
/*寻找和为定值的两个数
输入一个数组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个数的更多相关文章
- 【Data Structure & Algorithm】在排序数组中查找和为定值的两个数
在排序数组中查找和为定值的两个数 题目:输入一个已经按升序排序过的数组和一个数字,在数组中查找两个数,使得它们的和正好是输入的那个数字,要求时间复杂度是O(n).如果有多对数字的和等于输入的数字,输出 ...
- (1)Two Sum--求数组中相加为指定值的两个数
Given an array of integers, find two numbers such that they add up to a specific target number. The ...
- 【跟着子迟品 underscore】如何优雅地写一个『在数组中寻找指定元素』的方法
Why underscore (觉得这部分眼熟的可以直接跳到下一段了...) 最近开始看 underscore.js 源码,并将 underscore.js 源码解读 放在了我的 2016 计划中. ...
- 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 ...
- js数组去重 数组拼接 替换数组中的指定值 递归数组 判断数组中是否存在指定值 数组求和 根据条件判数组值
这是学习过程中记录的一些关于数组操作的常用属性或方法,记录一下方便以后使用. // 数组去重 var arr1 = [1,1,2,3,4,5,6,3,2,4,5,'a','b','c','a',6,7 ...
- 在数组中寻找出现次数大于N/K的数
给定一个int[]数组,给定一个整数k,打印所有出现次数大于N/k的数,没有的话,给出提示信息. === 核心思想:一次在数组中删除K个不同的数,不停的删除,直到剩下的数的种类不足K就停止删除,那么如 ...
- Java实现找出数组中重复次数最多的元素以及个数
/**数组中元素重复最多的数 * @param array * @author shaobn * @param array */ public static void getMethod_4(int[ ...
- 算法笔记_041:寻找和为定值的多个数(Java)
目录 1 问题描述 2 解决方案 1 问题描述 输入两个整数n和sum,要求从数列1,2,3,...,n中随意取出几个数,使得它们的和等于sum,请将其中所有可能的组合列出来. 2 解决方案 上述问题 ...
- 算法笔记_037:寻找和为定值的两个数(Java)
目录 1 问题描述 2 解决方案 2.1 排序夹逼法 1 问题描述 输入一个整数数组和一个整数,在数组中查找两个数,满足他们的和正好是输入的那个整数.如果有多对数的和等于输入的整数,输出任意一对即 ...
随机推荐
- [Unit Testing] Using Mockito Annotations - @Mock, @InjectMocks, @RunWith
Previously we have seen how to do Unit testing with Mockito; import org.junit.Test; import static or ...
- Android apk签名的两种方法
编辑推荐:稀土掘金,这是一个针对技术开发者的一个应用,你可以在掘金上获取最新最优质的技术干货,不仅仅是Android知识.前端.后端以至于产品和设计都有涉猎,想成为全栈工程师的朋友不要错过! 为了保证 ...
- pid 控制算法
http://blog.csdn.net/huangkangying/article/details/78129148 https://zh.wikipedia.org/wiki/PID%E6%8E% ...
- orocos_kdl学习(二):KDL Tree与机器人运动学
KDL(Kinematics and Dynamics Library)中定义了一个树来代表机器人的运动学和动力学参数,ROS中的kdl_parser提供了工具能将机器人描述文件URDF转换为KDL ...
- 基于Ubuntu 搭建 VNC 远程桌面服务
系统要求:Ubuntu 16.04.1 LTS 64 位操作系统 安装.启动 VNC VNC 远程桌面原理 注:本小节内容旨在帮助您更好地了解 Xorg.X11.VNC 等概念和原理,如果你不想了解原 ...
- redis性能测试报告
服务器配置:16核心,64G 250个并发读:250个并发写性能[内容8千byte] 163为读:164为写:
- [转]数据库性能优化之SQL语句优化1
一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统 ...
- SNF快速开发平台MVC-各种级联绑定方式,演示样例程序(包含表单和表格控件)
做了这么多项目,经常会使用到级联.联动的情况. 如:省.市.县.区.一级分类.二级分类.三级分类.仓库.货位. 方式:有表单需要做级联的,还是表格行上需要做级联操作的. 实现:实现方法也有很多种方式. ...
- SNF快速开发平台MVC-EasyQuery-拖拽生成SQL脚本
在之前介绍一下EasyQuery工具SNF开发平台WinForm-EasyQuery统计分析-效果-非常牛逼的报表查询工具 Winform开发框架之图表报表在线设计器-报表-SNF.EasyQuery ...
- Selenium:注解@FindBy、@FindBys、@FindAll的用法
方式有3种:@FindBy.@FindBys.@FindAll.下文对3中类型的区别和使用场景进行介绍 1)@FindBy @FindBy(id= "A") private Web ...