1051 : 补提交卡

来源:互联网 发布:更换淘宝店铺负责人 编辑:程序博客网 时间:2024/06/05 22:59

时间限制:2000ms
单点时限:1000ms
内存限制:256MB

描述

小Ho给自己定了一个宏伟的目标:连续100天每天坚持在hihoCoder上提交一个程序。100天过去了,小Ho查看自己的提交记录发现有N天因为贪玩忘记提交了。于是小Ho软磨硬泡、强忍着小Hi鄙视的眼神从小Hi那里要来M张”补提交卡”。每张”补提交卡”都可以补回一天的提交,将原本没有提交程序的一天变成有提交程序的一天。小Ho想知道通过利用这M张补提交卡,可以使自己的”最长连续提交天数”最多变成多少天。

输入

第一行是一个整数T(1 <= T <= 10),代表测试数据的组数。

每个测试数据第一行是2个整数N和M(0 <= N, M <= 100)。第二行包含N个整数a1, a2, … aN(1 <= a1 < a2 < … < aN <= 100),表示第a1, a2, … aN天小Ho没有提交程序。

输出

对于每组数据,输出通过使用补提交卡小Ho的最长连续提交天数最多变成多少。

样例输入

3  5 1  34 77 82 83 84  5 2  10 30 55 56 90  5 10  10 30 55 56 90

样例输出

76  59100

分析

由题目的意思可知道,选择补提交卡的天应该是连续的,这样才能达到最大连续天数;而且给的卡数M应当尽量用完,所以问题变成了从N天里选择连续的M天出来计算连续天数,返回最大连续天数。

#include <iostream>#include <vector>using namespace std;int main(){    int T;    cin>>T;    while(T--)    {        int N;        int M;        cin>>N>>M;        vector<int> forgotDays(N+2);        for(int i = 1;i<=N;++i)        {            int tmp;            cin>>tmp;            forgotDays[i] = tmp;        }        if(M>=N)        {            cout<<100<<endl;        }        else        {            forgotDays[0] = 0;            forgotDays[N+1] = 101;            int ans = 0;            for(int i = 0;i<=N;++i)            {                if(i+M+1 > N+1)                    break;                int tmp = forgotDays[i+M+1] - forgotDays[i] - 1;                ans = tmp>ans?tmp:ans;            }            cout<<ans<<endl;        }    }    return 0;}
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 苹果6p开不了机怎么办 苹果6p黑屏了怎么办 肚子胀反胃想吐怎么办 脸上干皮特别多怎么办 月光足还不了款怎么办 孩子不爱和小朋友玩怎么办 不知道怀孕抽烟了怎么办 校园欺凌来了该怎么办 拉的屎是绿色的怎么办 生完孩子痔疮痛怎么办 生过孩子脱肛该怎么办 生完宝宝有痔疮怎么办 毎次大便都脱肛怎么办 怀孕快生了便秘怎么办 35周孕晚期便秘怎么办 怀孕了老公出轨了怎么办 婆婆跟老公睡了怎么办 婆婆和老公互黏怎么办 15岁就掉头发怎么办 24岁经常掉头发怎么办 舍友打游戏太吵怎么办 家里的地砖想换怎么办 墙上的瓷砖掉了怎么办 瓷砖掉了一块瓷怎么办 白色裙子太透了怎么办 剑三石头插错了怎么办 四六级证书丢了怎么办 当月发票冲红了怎么办 当月发票红冲了怎么办 作废的发票扔了怎么办 发票公章盖错了怎么办 发票章盖的模糊怎么办 下的电影没字幕怎么办 荣耀8下载东西慢怎么办 考科目二下大雨怎么办 不求上进的人怎么办 连锁经营投的钱怎么办 古曼丽不想养了怎么办 百度云上传太慢怎么办 手机视频拍倒了怎么办 老师收手机不给怎么办