当前位置:   article > 正文

连续子序列

连续子序列

给定一个长度为N(10<N<100000)的正整数序列。每个正整数都小于等于10000,给定一个正整数S(S<100000000)。编写一个程序找到一个最小长度的子序列,要求这个子序列的和大于等于S。如果解不存在,则输出0。

输入格式

第一行两个整数N和S,第二行包括n个正整数表示数列A,两两之间用空格分隔。

输出格式

一个符合题目要求的整数。

输入/输出例子1

输入:

5 11

1 2 3 4 5

输出:

3

样例解释

具体代码

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int n,a[300000],mi=300000,c;
  4. long long s;
  5. int main()
  6. {
  7. cin>>n>>s;
  8. for(int i=1;i<=n;i++)
  9. {
  10. cin>>a[i];
  11. }
  12. for(int x=1;x<n;x++)
  13. {
  14. int y;
  15. for(y=x;y<=n;y++)
  16. {
  17. c+=a[y];
  18. if(c>=s)break;
  19. if(y==n)goto t;
  20. }
  21. mi=min(y-x+1,mi);
  22. t: ;
  23. c=0;
  24. }
  25. if(mi==300000)mi=0;
  26. cout<<mi;
  27. return 0;
  28. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/代码探险家/article/detail/805027
推荐阅读
相关标签
  

闽ICP备14008679号