剑指offer-42-和为s的连续整数序列

和为S的连续正数序列

http://www.nowcoder.com/questionTerminal/c451a3fd84b64cb19485dad758a55ebe

思路

  • 滑动窗口,用一个sumt记录一个队列中的和,如何sumt>sum,出队,sumt-=queue.poll(),小于sum,则入队
  • 求数组区间和就用前缀和,前缀和数组。然后求前缀和两个元素的差,感觉还是用滑动窗口啊。QAQ
import java.util.*;
public class Solution {
    public ArrayList<ArrayList<Integer> > FindContinuousSequence(int sum) {
        ArrayList<ArrayList<Integer>> arr=new ArrayList<>();
        int p=0,q=0,sumt=0;
        Queue<Integer> queue=new LinkedList<>();
        while(p<=q &&q<sum){
            if(sumt<sum){
                q++;
                queue.add(q);
                sumt+=q;
            }else if(sumt>sum){
                p++;
                sumt-=queue.poll();
            }else{
                arr.add(new ArrayList<>(queue));
                p++;
                sumt-=queue.poll();
            }
        }
        return arr;
    }
}
剑指offer与数据结构 文章被收录于专栏

本专栏包括剑指offer题目和一些刷题用的数据结构,单调栈,树状数组,差分数组,后面还会更新红黑树等较为复杂的数据结构

全部评论

相关推荐

Morpheus_:同 好奇什么题() 不过我一面确实是不想要直说了 xs
腾讯求职进展汇总
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务