C++ 语言 爱与愁的心痛

爱与愁的心痛

题目背景

(本道题目隐藏了两首歌名,找找看哪~~~)

《爱与愁的故事第一弹·heartache》第一章。

《我为歌狂》当中伍思凯神曲《舞月光》居然没赢给萨顶顶,爱与愁大神心痛啊~~~而且最近还有一些令人伤心的事情,都让人心痛(最近真的很烦哈)......

题目描述

最近有 n 个不爽的事,每句话都有一个正整数刺痛值(心理承受力极差)。爱与愁大神想知道连续 m 个刺痛值的和的最小值是多少,但是由于业务繁忙,爱与愁大神只好请你编个程序告诉他。

输入格式

第一行有两个用空格隔开的整数,分别代表 nm

2 到第 (n + 1) 行,每行一个整数,第 (i + 1) 行的整数 a_i 代表第 i 件事的刺痛值 a_i

输出格式

输出一行一个整数,表示连续 m 个刺痛值的和的最小值是多少。

样例 #1

样例输入 #1

```

8 3

1

4

7

3

1

2

4

3

```

样例输出 #1

```

6

```

提示

数据规模与约定

  • 对于 30\\% 的数据,保证 n \\leq 20

  • 对于 60\\% 的数据,保证 n \\leq 100

  • 对于 90\\% 的数据,保证 n \\leq 10\^3

  • 对于 100\\% 的数据,保证 0 \\leq m \\leq n \\leq 3 \\times 10\^31 \\leq a_i \\leq 100

cpp 复制代码
#include<iostream>
using namespace std;
#define MAX 3000+5
int a[MAX];
int b[MAX];	  
int main() {

	int  n, m;
	cin >> n >> m;
	int min_ = 0;
	for (int i = 0; i < n; i++) { //录入数据
		cin >> a[i];
		min_ += a[i];
	}
	if (m != n)	//如果m与n一直,就是所有元素的和
		for (int i = 0; i < n - m; i++) { //一共几组数

			for (int j = 0; j < m; j++)	 //这个循环求第几组的和
				b[i] += a[i + j];

			min_ = min(min_, b[i]);

		}
	printf("%d\n", min_);
	return 0;
}
相关推荐
hunandede20 分钟前
av_image_get_buffer_size 和 av_image_fill_arrays
c++
寻找码源34 分钟前
【头歌实训:利用kmp算法求子串在主串中不重叠出现的次数】
c语言·数据结构·算法·字符串·kmp
Matlab精灵35 分钟前
Matlab科研绘图:自定义内置多款配色函数
算法·matlab
诚丞成1 小时前
滑动窗口篇——如行云流水般的高效解法与智能之道(1)
算法
手握风云-1 小时前
数据结构(Java版)第二期:包装类和泛型
java·开发语言·数据结构
怀澈1222 小时前
高性能服务器模型之Reactor(单线程版本)
linux·服务器·网络·c++
chnming19872 小时前
STL关联式容器之set
开发语言·c++
带多刺的玫瑰2 小时前
Leecode刷题C语言之统计不是特殊数字的数字数量
java·c语言·算法
爱敲代码的憨仔2 小时前
《线性代数的本质》
线性代数·算法·决策树
威桑2 小时前
MinGW 与 MSVC 的区别与联系及相关特性分析
c++·mingw·msvc