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;
}
相关推荐
沙威玛_LHE2 小时前
树和二叉树
数据结构·算法
py有趣4 小时前
LeetCode算法学习之两数之和 II - 输入有序数组
学习·算法·leetcode
夏鹏今天学习了吗4 小时前
【LeetCode热题100(62/100)】搜索二维矩阵
算法·leetcode·矩阵
吃着火锅x唱着歌6 小时前
LeetCode 1128.等价多米诺骨牌对的数量
算法·leetcode·职场和发展
ᐇ9596 小时前
Java HashMap深度解析:数据结构、原理与实战指南
java·开发语言·数据结构
十八岁讨厌编程6 小时前
【算法训练营 · 补充】LeetCode Hot100(中)
算法·leetcode
橘颂TA6 小时前
【剑斩OFFER】算法的暴力美学——最小覆盖字串
算法·c/c++·就业
wearegogog1236 小时前
基于混合蛙跳算法和漏桶算法的无线传感器网络拥塞控制与分簇新方法
网络·算法
程序员龙一6 小时前
C++之static_cast关键字
开发语言·c++·static_cast
奶茶树7 小时前
【C++/STL】map和multimap的使用
开发语言·c++·stl