XDOJ 1307 汪聚聚的小目标(week1-XDUACM)

版权声明:本文为博主原创文章,转载需标明出处。 https://blog.csdn.net/coderDogg/article/details/80334883

问题 M: 汪聚聚的小目标

时间限制: 1 Sec  内存限制: 128 MB
提交: 154  解决: 64
[提交][状态][讨论版]

题目描述

优秀的wang9898最近又定了个小目标,成为世界首富。被齐齐批评好高骛远,先赚到m元再说吧。wang9898很不服气,他想向齐齐证明自己的能力
已知总共n天,第i天wang9898工作能收益ai元,他打算在这n天里选择一段连续的时间工作,总共赚超过m元,为了显现出自己赚钱能力高超,wang9898想在最短的时间里完成齐齐给的目标,请你帮助wang9898计算一下,他最少需要花多少天能达成目标(或者根本不可能)

输入

第一行一个整数T,表示有T组数据
对于每组数据
第一行 两个整数n,m(1≤n≤1e5)
第二行 n个整数 第i个数字表示ai

输出

对于每组数据,输出最小天数,如果无解则输出0

样例输入

3
10 15
5 1 3 5 10 7 4 9 2 8
5 11
1 2 3 4 5
5 8
1 1 1 1 1

样例输出

2
3

大概思路:找最小天数可以的金额总和可以大于等于m即可,这里的m的数据范围未给定,我们可以默认为int

如何求最小天数的金额总和大于等于m呢,我们可以利用尺取法

参考博客:https://blog.csdn.net/consciousman/article/details/52348439

贴下AC代码:

#include <iostream>
#include <algorithm>
#include <cstdio>
#define INF 0x3f3f3f3f
using namespace std;
int a[100001];
int main(){
    int T,n,m;
//    freopen("in.in","r",stdin);
    cin>>T;
    while(T--){
        cin>>n>>m;
        for(int i=0;i<n;i++)
            cin>>a[i];
        int r=0,l=0,sum=0,ans=INF;
        while(l<=n){
            while(r<n&&sum<m) sum+=a[r++];
            if(sum<m) break;
            ans=min(ans,r-l);
            sum-=a[l++];
        }
        if(ans==INF) ans=0;
        cout<<ans<<endl;
    }
    return 0;
}


阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页