标签:题目 ack turn == amp 循环条件 back font 并且
输出所有和为S的连续正数序列。序列内按照从小至大的顺序,序列间按照开始数字从小到大的顺序
思路:定义两个变量small和big,如果[small,big]之间的和tmp大于sum,那么tmp - small,并且++small;
如果他们之间的和小于sum,那么就++big,tmp += big,注意循环条件是small 要小于(1 + sum) / 2;因为如果small =(1 + sum) / 2;那么至少有两个数加起来肯定大于sum不符合条件。
class Solution { public: vector<int> rowResult(int start,int end){ vector<int> res; for(int i = start;i <= end;++i){ res.push_back(i); } return res; } vector<vector<int> > FindContinuousSequence(int sum) { vector<vector<int> > result; if(sum < 3){ return result; } int small = 1,big = 2; int mid = (1 + sum) / 2; int tmp = small + big; while(small < mid){ if(tmp == sum){ result.push_back(rowResult(small,big)); } while(small < mid && tmp > sum){ tmp -= small; ++small; if(tmp == sum){ result.push_back(rowResult(small,big)); } } ++big; tmp += big; } return result; } };
标签:题目 ack turn == amp 循环条件 back font 并且
原文地址:http://www.cnblogs.com/dingxiaoqiang/p/7496293.html