slide window

given a sum,find continous nums add equals sum
like 100= 9 10 11 12 13 14 15 16;
=18 19 20 21 22

#include <iostream>
#include <vector>


using namespace std;

class Solution{
public:
    vector<vector<int> > findSequence(int sum){
        //slide window,watch out start ,end 
        int start=0,end=0,size=sum-1;
        
        vector<vector<int> >res;
        vector<int> vec;
        if(sum<=2){
            return res;
        }
        //init
        vector<int> arr(size);
        for(int i=1;i<sum;i++){
            arr[i-1]=i;
        }
        int subSum=arr[0];

        while(start<=size-2 && end<=size-1){
            //[start...end]
            while(subSum<sum){
                end++;
                subSum+=arr[end];
                
                
            }
            
            while(subSum>sum){
                //[start...end]
                subSum-=arr[start];
                start++;
            }

            if(subSum==sum){
                for(int i=start;i<=end;i++){
                    vec.push_back(arr[i]);
                }
                res.push_back(vec);
                vec.clear();
                end++;
                subSum+=arr[end];
            }
        }

        return res;

    }
};

int main(){
    int sum=100;
    vector<vector<int> > res;
    res=Solution().findSequence(sum);
    for(int i=0;i<res.size();i++){
        for(int j=0;j<res[i].size();j++){
            cout<<res[i][j]<<" ";
        }
        cout<<endl;
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容