• 剑指offer——和为s的连续正整数序列


    输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)。

    序列内的数字由小到大排列,不同序列按照首个数字从小到大排列。

    示例 1:

    输入:target = 9
    输出:[[2,3,4],[4,5]]
    示例 2:

    输入:target = 15
    输出:[[1,2,3,4,5],[4,5,6],[7,8]]

    思路:此类带有“连续序列”字眼的题,一般操作是滑动窗口法。先设置一个大小为0的窗口,left=1, right=1, 窗口内的数字之和为sum,通过比较sum和target,不断扩大有边界或缩小左边界。

    class Solution {
    public:
        vector<vector<int>> findContinuousSequence(int target) {
            //滑动窗口左右边界
            int left = 1, right = 1;
            int sum = 0;
            vector<vector<int>> res;
            while(left <= target / 2) {    //超过target一半后不可能存在连续两个数之和为target
                if(sum < target) {      //sum < target则继续扩展右边界
                    sum += right;
                    right++;
                }
                else if(sum > target) {  //sum > target则缩小左边界
                    sum -= left;
                    left++;
                }
                else {            //找到了一个满足条件的序列
                    //记录结果
                    vector<int> vec;
                    //左开右闭的区间
                    for(int i = left; i < right; ++i) {
                        vec.push_back(i);
                    }
                    res.push_back(vec);
                    //左边界向右移动一格
                    sum -= left;
                    left++;
                }
            }
            return res;
        }
    };
  • 相关阅读:
    redis配置认证密码以及远程访问
    Mybatis缓存配置
    Node.Js安装
    1.ArcGis几何图形之几何计算
    MessagePack 新型序列化反序列化方案
    Redis(六)-数据类型
    Redis(五)-数据库
    Redis(四)-配置
    Redis(三)-Ubuntu下安装
    Redis(二)-Win系统下安装
  • 原文地址:https://www.cnblogs.com/joker1937/p/12831224.html
Copyright © 2020-2023  润新知