题目

  输入一个递增排序的数组和一个数字 s,在数组中查找两个数,得它们的和正好是 s。如果有多对数字的和等于 s,输出任意一对即可

思路

  我们先在数组中选择两个数字,如果它们的和等于输入的 s,我们就找到了要找的两个数字。如果和小于 s 呢?我们希望两个数字的和再大一点。由于数组已经排好序了,我们可以考虑选择较小的数字后面的数字。因为排在后面的数字要大一些,那么两个数字的和也要大一些, 就有可能等于输入的数字 s 了。同样, 当两个数字的和大于输入的数字的时候,我们可以选择较大数字前面的数字,因为排在数组前面的数字要小一些。

#include <iostream>
#include <vector>
using namespace std; class Solution
{
public:
void find_num_with_sum(const vector<int> &v,const int &sum);
}; void Solution::find_num_with_sum(const vector<int> &v,const int &sum)
{
if(v.size()<=||v.empty())
return; vector<int>::const_iterator begin=v.begin();
vector<int>::const_iterator end=--v.end(); while(begin<end)
{
if((*begin+*end)==sum)
{
cout<<*begin<<'\t'<<*end<<endl;
break;
}
else if((*begin+*end)<sum)
++begin;
else
--end;
}
}
int main()
{
vector<int> v{,,,,,};
Solution s;
s.find_num_with_sum(v,);
return ;
}

code

class Solution {
public:
vector<int> FindNumbersWithSum(vector<int> arr,int sum) {
if(arr.size()==)
return {};
else if(arr[]>sum)
return {}; int i=,j=arr.size()-;
vector<int> res;
while(i<j)
{
if(arr[i]+arr[j]==sum)
{
res.push_back(arr[i]);
res.push_back(arr[j]);
break;
}
if(i<j&&arr[i]+arr[j]>sum)
--j;
if(i<j&&arr[i]+arr[j]<sum)
++i;
}
return res;
}
};

题目

  输入一个正数 s,打印出所有和为 s 的连续正数序列(至少两个数)

思路

  考虑用两个数 small 和 big 分别表示序列的最小值和最大值。首先把 small 初始化为 1,big 初始化为 2。如果从 small 到 big 的序列的和大于 s,我们可以从序列中去掉较小的值,也就是增大 small 的值。如果从 small 到 big 的序列的和小于 s,我们可以增大 big,让这个序列包含更多的数字。因为这个序列至少要有两个数字,我们一直增加 small 到(1+s)/2 为止。

#include <iostream>
#include <vector>
using namespace std; class Solution
{
public:
void find_sequence(const int &sum);
};
void Solution::find_sequence(const int &sum)
{
if(sum<=)
return; int small=;
int big=;
int middle=(sum+)/;
int curr_sum=small+big; while(small<middle)
{
if(curr_sum==sum)
{
for(int i=small;i<=big;++i)
cout<<i<<'\t';
cout<<endl;
} while(curr_sum<sum&&small<middle)
{
++big;
curr_sum+=big;
if(curr_sum==sum)
{
for(int i=small;i<=big;++i)
cout<<i<<'\t';
cout<<endl;
break;
}
}
curr_sum-=small;
++small;
}
}
int main()
{
Solution s;
s.find_sequence();
return ;
}

code2

class Solution {
public:
vector<vector<int> > FindContinuousSequence(int sum) {
if(sum<)
return {}; int smallNum=,bigNum=;
vector<vector<int>> res;
while(smallNum<bigNum)
{
int curSum=(smallNum+bigNum)*(bigNum-smallNum+)/;
if(curSum<sum)
++bigNum; if(curSum==sum)
{
vector<int> tmp;
for(int i=smallNum;i<=bigNum;++i)
tmp.push_back(i);
res.push_back(tmp);
++smallNum;
} if(curSum>sum)
++smallNum;
}
return res;
}
};

拓展

  通常用循环求一个连续序列的和,但每次操作后的序列和操作之前的序列比大部分都是一样的,只是增加或减少了一个数字,因此可以再之前的序列基础上求后一个序列。

和为 s 的两个数字(和为 s 的连续正数序列)的更多相关文章

  1. 面试题41:和为s的两个数字 || 和为s的连续正数序列

    和为s的两个数字 题目:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. 有点类似于夹逼的思想 注意两个int相加的和要用lo ...

  2. 和为s的两个数字 和为s的连续正数序列

    输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s,如果有多对数字的和等于s,输出任意一对即可. #include <iostream> using namesp ...

  3. 和为S的两个数VS和为S的连续正数序列

    其实这个题目如果没有限制时间复杂度的话,那么就很简单了,一遍一遍地扫描吧.时间复杂度肯定就是 O(n2)啰.但是这题目肯定不会这么简单,否则就是小学生的水平了嘛. 其实我刚到这题的时候想到的是用二叉查 ...

  4. 和为S的两个数字VS和为s的连续正数序列

    题目:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. 例如输入数组1.2.4.7.11.15和数字15.由于4+11=15, ...

  5. 【面试题041】和为s的两个数字VS和为s的连续正数序列

    [面试题041]和为s的两个数字VS和为s的连续正数序列 题目一:     输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. ...

  6. 【剑指offer】面试题41:和为 s 的两个数字 VS 和为 s 的连续正数序列

    题目: 输出所有和为S的连续正数序列.序列内按照从小至大的顺序,序列间按照开始数字从小到大的顺序 思路: small代表序列最小数字,large代表序列最大数字.初始化small为1,large为2. ...

  7. 面试题41:和为s的两个数字VS和为s的连续正数序列

    题目一:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和为s,输出任意一对即可. vector<int> findNumberwWithSu ...

  8. [剑指Offer]41.和为S的两个数字 VS 和为S的连续正数序列

    [剑指Offer]41 和为S的两个数字 VS 和为S的连续正数序列 Leetcode T1 Two Sum Given an array of integers, return indices of ...

  9. 面试题 41 和为s的两个数字VS 和为S的连续整数序列

    (1)和为S的两个数字 bool findNumberWithSum(int data[], int length, int sum, int &numb1, int &numb2){ ...

随机推荐

  1. python-day8-元组的内置方法

    #为何要有元组,存放多个值,元组不可变,更多的是用来做查询# t=(1,[1,3],'sss',(1,2)) #t=tuple((1,[1,3],'sss',(1,2)))# print(type(t ...

  2. thinkphp %s %d %f

    %s -- 表示字段串%d -- 表示整形数字%f -- 表示浮点数 例子:$order_number = $m_ebay_order_numbers->where("ebay_ord ...

  3. 从0开始接触html--第一天学习内容总结

    第一天 总结: h1-h6 p 段落 hr br 有序 ol li 无序 ul li 定义列表 dl dt dd 块级元素:独占一行,h1-h6 p hr div 行内元素:共占一行, em和i st ...

  4. HDU-1272 小希的迷宫 (并查集、判断图是否为树)

    Description 上次Gardon的迷宫城堡小希玩了很久(见Problem B),现在她也想设计一个迷宫让Gardon来走.但是她设计迷宫的思路不一样,首先她认为所有的通道都应该是双向连通的,就 ...

  5. iOS UI-常用控件

    #import "ViewController.h" @interface ViewController ()<UITextFieldDelegate> // 标题标签 ...

  6. linux abstract model of virtual memory

  7. 《Python》 字典

    一.字典 字典是Python的基础数据类型之一: 字典可以存储大量的数据,关系型数据: 同样他也是Python中唯一的映射类数据类型. 数据类型的分类: 可变的(不可哈希的)数据类型:list,dic ...

  8. git 添加review的相关操作

    git主机上涉及到的操作: 185 git branch 186 git pull 187 git branch 188 git checkout -b wangcheng 189 git log 1 ...

  9. bean的实例化

    bean的实例化 构造器方式 静态方法方式 普通工厂方式 一般的,默认bean实例化使用的是构造器方式,调用的是无参的构造方法 package com.Model; public class Dog ...

  10. SpringContextUtil spring上下文获取工具类

    package com.midea.biz; import org.springframework.beans.BeansException; import org.springframework.c ...