和为 s 的两个数字(和为 s 的连续正数序列)
题目
输入一个递增排序的数组和一个数字 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 的连续正数序列)的更多相关文章
- 面试题41:和为s的两个数字 || 和为s的连续正数序列
和为s的两个数字 题目:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. 有点类似于夹逼的思想 注意两个int相加的和要用lo ...
- 和为s的两个数字 和为s的连续正数序列
输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s,如果有多对数字的和等于s,输出任意一对即可. #include <iostream> using namesp ...
- 和为S的两个数VS和为S的连续正数序列
其实这个题目如果没有限制时间复杂度的话,那么就很简单了,一遍一遍地扫描吧.时间复杂度肯定就是 O(n2)啰.但是这题目肯定不会这么简单,否则就是小学生的水平了嘛. 其实我刚到这题的时候想到的是用二叉查 ...
- 和为S的两个数字VS和为s的连续正数序列
题目:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. 例如输入数组1.2.4.7.11.15和数字15.由于4+11=15, ...
- 【面试题041】和为s的两个数字VS和为s的连续正数序列
[面试题041]和为s的两个数字VS和为s的连续正数序列 题目一: 输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和等于s,输出任意一对即可. ...
- 【剑指offer】面试题41:和为 s 的两个数字 VS 和为 s 的连续正数序列
题目: 输出所有和为S的连续正数序列.序列内按照从小至大的顺序,序列间按照开始数字从小到大的顺序 思路: small代表序列最小数字,large代表序列最大数字.初始化small为1,large为2. ...
- 面试题41:和为s的两个数字VS和为s的连续正数序列
题目一:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s.如果有多对数字的和为s,输出任意一对即可. vector<int> findNumberwWithSu ...
- [剑指Offer]41.和为S的两个数字 VS 和为S的连续正数序列
[剑指Offer]41 和为S的两个数字 VS 和为S的连续正数序列 Leetcode T1 Two Sum Given an array of integers, return indices of ...
- 面试题 41 和为s的两个数字VS 和为S的连续整数序列
(1)和为S的两个数字 bool findNumberWithSum(int data[], int length, int sum, int &numb1, int &numb2){ ...
随机推荐
- elasticsearch term match multi_match区别
转自:http://www.cnblogs.com/yjf512/p/4897294.html match 最简单的一个match例子: 查询和"我的宝马多少马力"这个查询语句匹配 ...
- notepad++设置右键
Windows Registry Editor Version 5.00[HKEY_CLASSES_ROOT\*\Shell\NotePad++][HKEY_CLASSES_ROOT\*\Shell\ ...
- 072——VUE中vuex之使用mutations修改购物车仓库数据
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- PHP:第一章——PHP中的算术运算符/递增、递减运算符/赋值运算符
算术运算符 //$a=10; $b=5; //取反: //echo -$a;//输出:-10: //加法: //echo $a+$b;//输出:15 //减法: //echo $a-$b;//输出:5 ...
- UVALive 5984
题目链接:Save the Students! #include<stdio.h> #include<string.h> #include<iostream> #i ...
- SQL Server 对比数据库差异
一.视图和存储过程比较 [原理]利用系统表“sysobjects"和系统表“syscomments”,将数据库中的视图和存储过程进行对比.系统表"sysobjects"之 ...
- 109. Magic of David Copperfield II 构造 难度:2
109. Magic of David Copperfield II time limit per test: 0.25 sec. memory limit per test: 4096 KB The ...
- POJ 2586 Y2K Accounting Bug 贪心 难度:2
Y2K Accounting Bug Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10537 Accepted: 52 ...
- 获取URL中的链接(可中文也可英文)
//既能获取中文url也能英文function getUrlParam(key) { // 获取参数 var url = window.location.search; // 正则筛选地址栏 var ...
- 玩转X-CTR100 l STM32F4 l PS2无线手柄-4WD智能小车
我造轮子,你造车,创客一起造起来!更多塔克创新资讯[塔克社区 www.xtark.cn ][塔克博客 www.cnblogs.com/xtark/ ] 前面已介绍X-CTR100控制器解码PS2无线手 ...