Cpp-24-09-15
洛谷P1216
题目描述
最近有 nn 个不爽的事,每句话都有一个正整数刺痛值(心理承受力极差)。爱与愁大神想知道连续 mm 个刺痛值的和的最小值是多少,但是由于业务繁忙,爱与愁大神只好请你编个程序告诉他。
输入格式
第一行有两个用空格隔开的整数,分别代表 n和m。
第 22 到第 (n+1)行,每行一个整数,第 (i+1)行的整数 ai代表第 i件事的刺痛值 ai。
提交答案(一重循环)
```C++
define _CRT_SECURE_NO_WARNINGS 1
include // cin,cout
include //数学函数
include //C语言的printf,scanf
include
include
using namespace std;
int main() {
int n, m;
int sum=0;
int min ;
int a[3000] = {0};
int tmp;
cin >> n >> m;
for (int i = 0; i < n; i++) {
cin >> tmp; //接受变量
if (i < m) {
//如果是刚开始输入的前m个数字,直接累加
sum += tmp;
min = sum;//暂时认为最小值是前m个的
}
else
sum = sum + tmp - a[i%m];//如果是后续输入的超过m个数字,累加之后减去前面的第m个
a[i % m] = tmp; //赋值给数组,必须在sum = sum + tmp - a[i%m];,之前,这样才是先计算sum,再覆盖数组的值。
//判断是否是最短的
if (sum < min)
min = sum;
}
cout << min;
return 0;
}
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 The Site Of Liu!


