和为 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){ ...
随机推荐
- NRF51822+STM32bootload——typedef void (*Fun) (void) 理解
1.typdef 用法如下所示 typedef unsigned char uint8_t; typedef unsigned short int uint16_t; typedef unsigned ...
- install rabbitvcs in ubuntu16.04
reference: https://github.com/rabbitvcs/rabbitvcs how to install : sudo apt-get install rabbitvcs-cl ...
- CSS中的长度单位及颜色表示
CSS中的长度单位及颜色表示 长度单位: px:像素,绝对单位 em:相对单位,如果用于font-size属性本身,则是相对于父元素的font-size.若用于其他属性(width,height ...
- sgu 130Circle dp
130. Circle time limit per test: 0.25 sec. memory limit per test: 4096 KB On a circle border there a ...
- sgu 125 Shtirlits dfs 难度:0
125. Shtirlits time limit per test: 0.25 sec. memory limit per test: 4096 KB There is a checkered fi ...
- Python中简化的验证码功能实现
#!/usr/bin/env python # _*_ encoding:utf-8 _*_ # author:snate import random def generate_auth_code() ...
- 关系数据库ORMlite的用法;
首先要在 http://ormlite.com/releases 页面下载两个jar 包: (1)core列表下的jar包: (2)android列表下的jar包. 将上面的两个jar包下载后放到An ...
- MySQL 中Index Condition Pushdown (ICP 索引条件下推)和Multi-Range Read(MRR 索引多范围查找)查询优化
一.ICP优化原理 Index Condition Pushdown (ICP),也称为索引条件下推,体现在执行计划的上是会出现Using index condition(Extra列,当然Extra ...
- DevExpress v17.2新版亮点—WinForms篇(一)
用户界面套包DevExpress v17.2终于正式发布,本站将以连载的形式为大家介绍各版本新增内容.开篇介绍了DevExpress WinForms v17.2 Data Grid Control ...
- Error:Cannot compile Groovy files: no Groovy library is defined for module 'xxxx' 错误处理
出现 Error:Cannot compile Groovy files: no Groovy library is defined for module 'xxxx' 只要在 project str ...