和为S的连续正数序列

youzhihua · · 898 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

题目描述

小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100。但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数)。没多久,他就得到另一组连续正数和为100的序列:18,19,20,21,22。现在把问题交给你,你能不能也很快的找出所有和为S的连续正数序列? Good Luck!

示例:

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

思路

1.这道题可以使用“滑动窗口”+“双指针”的思想解决。
2.设置两个指针,这两个指针用于标识目前所属的范围。

  • 当前范围内的和,可以通过等差数列的求和公式 sum=(low+high)(high-low+1)/2* 求出
  • 当sum>target时,low指针右移
  • 当sum<target时,high指针右移
  • 当sum == target时,存下当前范围内的数字
  • 当low >= high时,终止操作

Java代码实现

public class Solution {
    public int[][] findContinuousSequence(int sum) {
        ArrayList<int[]> res = new ArrayList<>();
        int low = 1;
        int high = 2;
        while(low < high){
            int cur = (low+high)*(high-low+1)/2;
            if(cur == sum){
                int[] array = new int[high-low+1];
                for (int i = low; i <= high; i++) {
                    array[i-low] = i;
                }
                res.add(array);
                low++;
                high++;
            }else if(cur > sum){
                low++;
            }else{
                high++;
            }
        }
        int[][] resArray = new int[res.size()][];
        return res.toArray(resArray);
    }
}

Golang代码实现

func findContinuousSequence(target int) [][]int {
    res := make([][]int,0)

    low,high := 1,2
    
    for low < high{
        cur := (low+high) * (high-low+1) / 2
        if cur == target{
            curSlice := make([]int,high-low+1)
            for i:=low;i<=high;i++{
                curSlice[i-low] = i
            }
            res = append(res, curSlice)
            low++
            high++
        }else if cur < target{
            high++
        }else{
            low++
        }
    }
    return res
}

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:youzhihua

查看原文:和为S的连续正数序列

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

898 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传