在数组中寻找和为定值的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 问题描述 输入一个整数数组和一个整数,在数组中查找两个数,满足他们的和正好是输入的那个整数.如果有多对数的和等于输入的整数,输出任意一对即 ...
随机推荐
- (转)GrabPass捕捉屏幕纹理
转自:http://blog.sina.com.cn/s/blog_89d90b7c0102va4m.html 最近在看热扭曲效果,里面用到了GrabPass. 之前看过官方翻译版本的说明http:/ ...
- PRTG安装
1.去官网下载,记录下试用秘钥,然后执行安装 2. 3. 4.输入秘钥 5. 6.安装完成后自动转到如下页面,点击启动Guru 7. 8. 9. 10.输入prtgadmin,密码prtgadmin ...
- Linux下在root权限下临时使用其它用户运行命令
一.简述 当我们在使用Linux时,经常需要在root权限下执行某些命令,或者在/etc/rc.d/rc.local中写一些角本.而如果某些角本必须使用非root用户时,直接su是不行的,比如Elas ...
- 关于JAVA 中的Configuration类
properties文件是Java平台默认的配置文件格式,其优点是格式清晰,简单易懂,使用commons-configuration读取properties文件也比较简单,代码如下: 基本用法: 1. ...
- Oracle 12c 添加scott用户
对于熟悉Oracle或者接触过Oracle的人,scott这个用户大家一定相当的熟悉.12c推出了可插拔数据库,在一个容器cdb中以多租户的形式同时存在多个数据库pdb.pdb中默认不包含scott用 ...
- Uploadify导致Chrome频繁崩溃Crash
上传功能是工作中经常会遇到的问题,应该作为开发标配的技能每个人都会. 我选用的是Uploadify 3.1.2进行上传,使用方法参考之前的一篇文章, 今天记录下一个我遇到的很神奇的bug chrome ...
- JAVA Spring boot相关技巧
1. 注册多实例.@Scope("prototype") 2. 手工方式获取注册的实例. @Autowired private ServletContext servletCont ...
- 转 $(document).ready()与window.onload的区别
$(document).ready()和window.onload在表单上看都是页面加载时我们就去执行一个函数或动作,但是在具体的细节上$(document).ready()和window.onloa ...
- ListView中的Item点击事件和子控件的冲突或者item点击没有反应的解决的方法
fragment中加入了button和checkbox这些控件.此时这些子控件会将焦点获取到.所以经常当点击item时变化的是子控件.item本身的点击没有响应. 这时候就能够使用descendant ...
- RelativeLayout 布局参数
今天调布局的时候 想把界面做成横屏竖屏都可以的 突然发现之前理解的android:布局参数都是有问题的 今天贴出来 下次自己也记得 以下大部为用在RelativeLayout中的一些参数: andro ...