题意:

      给你一个正整数序列,问你在里面找到一个最短的子序列,要求子序列的和大于等于k,输出序列长度。

思路:

      这个序列的每个数字都是正整数,那么就比较好想了,我们可以直接枚举终点,然后每次当当前和大于等于k的时候就把前面的markid(markid初始为1)点缩进,得到前端(我的是得到前端的下一个,这个无所谓,就是一个加不加1的事),然后更新最小值就行了,这样的时间复杂度是O(n)的,还有一个O(n*logn)的方法,就是白书上说的那个,我们可以枚举终点,然后二分去找起点,因为所有数字都是正整数,所以是单调的,找到最靠后的起点作为当前终点的起点,然后更新最小值就行了。

#include<stdio.h>

#define N 100000 + 10

int num[N];

int main ()

{

  int n ,m ,i ,Ans;

  while(~scanf("%d %d" ,&n ,&m))

  {

      for(i = 1 ;i <= n ;i ++)

      scanf("%d",&num[i]);

      int nows = 0 ,nowid;

      for(Ans = 0 ,nowid = 1 ,i = 1 ;i <= n ;i ++)

      {

         nows += num[i];

         if(nows >= m)

         {

            while(nows - num[nowid] >= m)

            {

                nows -= num[nowid];

                nowid ++;

            }

            if(!Ans || Ans > i - nowid + 1)

            Ans = i - nowid + 1;

         }

      }

      printf("%d\n" ,Ans);

   }

   return 0;

}

最新文章

  1. 【BZOJ3314】 [Usaco2013 Nov]Crowded Cows 单调队列
  2. android audio无法自动播放
  3. linq to sql 输出SQL语句
  4. Iterator遍历器 调用Symbol.Iterator属性,遍历器对象。
  5. Ubuntu 12.04 LTS 及ubuntu14.10 -- NFS安装
  6. 5.5 Selenium2中的元素定位
  7. Football(POJ3071)
  8. XML Helper XML操作类
  9. WMDestroy函数调用inherited,难道是为了调用子类覆盖函数?还有这样调用的?
  10. SVM详解
  11. Android UI ActionBar功能-自定义Tab功能
  12. 【Cocos2d-x游戏引擎开发笔记(25)】XML解析
  13. poj 1975 Median Weight Bead(传递闭包 Floyd)
  14. window.opener的用法
  15. PHP将汉字转为拼音
  16. layui table默认选中指定行
  17. Eclipse中的快捷键
  18. 6个免费的C++图形和游戏库
  19. Centos7.3+uwsgi+Nginx部署Django程序
  20. jquery.validate动态更改校验规则

热门文章

  1. C语言中储存类别和内存管理
  2. SQL字符串传参
  3. XUPT-D
  4. PriorityQueue 是线性结构吗?90%的人都搞错了!
  5. vim命令c编程
  6. 攻防世界 reverse Mysterious
  7. WPF3D立方体图形展开动画思路
  8. Spring Cloud 升级之路 - 2020.0.x - 2. 使用 Undertow 作为我们的 Web 服务容器
  9. 【oracle学习笔记02】Oracle Architecture —— Process Structure
  10. 茫茫内存,我该如何用 windbg 找到你 ?