爱与愁的心痛
题目背景
(本道题目隐藏了两首歌名,找找看哪~~~)
《爱与愁的故事第一弹·heartache》第一章。
《我为歌狂》当中伍思凯神曲《舞月光》居然没赢给萨顶顶,爱与愁大神心痛啊~~~而且最近还有一些令人伤心的事情,都让人心痛(最近真的很烦哈)……
题目描述
最近有 n n n 个不爽的事,每句话都有一个正整数刺痛值(心理承受力极差)。爱与愁大神想知道连续 m m m 个刺痛值的和的最小值是多少,但是由于业务繁忙,爱与愁大神只好请你编个程序告诉他。
输入格式
第一行有两个用空格隔开的整数,分别代表 n n n 和 m m m。
第 2 2 2 到第 ( n + 1 ) (n + 1) (n+1) 行,每行一个整数,第 ( i + 1 ) (i + 1) (i+1) 行的整数 a i a_i ai 代表第 i i i 件事的刺痛值 a i a_i ai。
输出格式
输出一行一个整数,表示连续 m m m 个刺痛值的和的最小值是多少。
样例 #1
样例输入 #1
8 3
1
4
7
3
1
2
4
3
样例输出 #1
6
提示
数据规模与约定
- 对于 30 % 30\% 30% 的数据,保证 n ≤ 20 n \leq 20 n≤20。
- 对于 60 % 60\% 60% 的数据,保证 n ≤ 100 n \leq 100 n≤100。
- 对于 90 % 90\% 90% 的数据,保证 n ≤ 1 0 3 n \leq 10^3 n≤103。
- 对于 100 % 100\% 100% 的数据,保证 0 ≤ m ≤ n ≤ 3 × 1 0 3 0 \leq m \leq n \leq 3 \times 10^3 0≤m≤n≤3×103, 1 ≤ a i ≤ 100 1 \leq a_i \leq 100 1≤ai≤100。
---------------------------------------------------------分割线---------------------------------------------------------
CODE
//给个免费的赞吧,谢谢(●'◡'●)!
#include<bits/stdc++.h>
using namespace std;
int main(){
int n,m;cin>>n>>m;
deque<int>dq{istream_iterator<int>(cin),istream_iterator<int>()};
// for(int i=0;i<n;i++){
// int a;cin>>a;
// dq.push_back(a);
// }
int min=300100,count=0,sum=0;
for(auto it=dq.begin();it<(dq.end()+1);++it){
if(count<m){
sum+=*it;
++count;
}else{
min=sum<min?sum:min;
sum-=dq.front();
dq.pop_front();
sum+=*it;
}
}
cout<<min;
return 0;
/*
还是很简单的一道题,刚好重温了一下STL的deque(double-ended queue),就用dq实现了,
关于我的博客,如果你有任何不解的地方可私信我,
我是学生党,技术有限,但是一定尽力解答,如果能帮助到你就是我的动力使然.
*/
}