和为s的两个数字 题目:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. 有点类似于夹逼的思想 注意两个int相加的和要用long long类型比较规范 bool FindNumbersWithSum(int data[], int length, int sum, int* num1, int* num2) { ) return false; ; ; while (i < j) { long long tempSum =…
(1)和为S的两个数字 bool findNumberWithSum(int data[], int length, int sum, int &numb1, int &numb2){ // data 中的数字序列递增 ) return NULL ; ; ; while(low < high){ int tp = data[low] + data[high] ; if( tp == sum){ numb1 = data[low]; numb2 = data[high]; return…
输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s,如果有多对数字的和等于s,输出任意一对即可. #include <iostream> using namespace std; //复杂度为O(n) bool findnumber(int data[],int length,int sum,int &num1,int &num2) { bool found=false; ) return found; ,high=length-; while(low…
其实这个题目如果没有限制时间复杂度的话,那么就很简单了,一遍一遍地扫描吧.时间复杂度肯定就是 O(n2)啰.但是这题目肯定不会这么简单,否则就是小学生的水平了嘛. 其实我刚到这题的时候想到的是用二叉查找的方法进行.但是可能有点困难. 书上提供的方法固然是很巧妙的. 我们要抓住题目中数组的特点,是排好序的. 我们先定义两个指针.一个指头,一个指尾. 我们来计算start+end=16>15.于是知大了,咋办? 我们将end往后移一位.也就是如下了: 些时 1+11=12<15..咋办? 肯定是将…
题目: 输出所有和为S的连续正数序列.序列内按照从小至大的顺序,序列间按照开始数字从小到大的顺序 思路: small代表序列最小数字,large代表序列最大数字.初始化small为1,large为2. 如果序列当前和curSum大于要找的数s,则small往前移:如果序列当前和小于s,则large往前移.当然每次要更新curSum. 注意的是当curSum等于s时,要更新large 注意:有循环的,要注意循环内的各个分支,不要出现死循环.(连续两题了) 代码: class Solution {…
题目一:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和为s,输出任意一对即可. vector<int> findNumberwWithSum(vector<int>&data, int sum) { int n = data.size(); vector<int>result; ) return result; , right = n-; while (left < right) { if (data[le…
[面试题041]和为s的两个数字VS和为s的连续正数序列 题目一:     输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可.   思路一:     现在数组中固定一个数字,再依次判断数组中其他的n-1个数字与它的和是不是等于s, ——时间复杂度O(n)   思路二:     在数组中选择两个数字,如果他们的和等于s那么就找到了,     如果小于s呢,显然我们希望和更大一些,由于数组有序,可以考虑较小数字的后面的数字.因为…
[剑指Offer]41 和为S的两个数字 VS 和为S的连续正数序列 Leetcode T1 Two Sum Given an array of integers, return indices of the two numbers such that they add up to a specific target. You may assume that each input would have exactly one solution, and you may not use the s…
题目: 输入一个正数s,打印出所有和为s的连续正数序列(至少含有两个数).例如输入15,由于1+2+3+4+5=4+5+6=7+8=15,所以结果打印出3个连续序列1-5,,4-6和7-8. 思路: 题目求的是连续正数序列,而且至少含有两个数,那么我们可以从1,2这两个数开始, 以求和为9的所有连续序列为例,假设两个指针pSmall和pBig,分别指向正数序列的首尾,pSum表示序列之和,一开始pSmall=1,pBig=2,,pSum=3<9,序列需要包含更多的数,于是pBig+1,此时pSu…
题目:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. 例如输入数组1.2.4.7.11.15和数字15.由于4+11=15,因此输出4和11. 思路整理一下:最初我们找到数组的第一个数字和最后一个数字.首先定义两个指针,第一个指针指向数组的第一个(也就是最小的)数字,第二个指针指向数组的最后一个(也就是最大的)数字.当两个数字的和大于输入的数字时,把较大的数字往前移动:当两个数字的和小于数字时,把较小的数字往后移动:当相…