[洛谷]P5638 【CSGRound2】光骓者的荣耀

这是一个C++程序,用于计算输入序列的前缀和,并找出序列中连续子序列的最大和。程序读取整数n和k,接着读入n-1个整数构成序列,通过动态更新前缀和sum[],找到序列中k项的最大子序列和。最终输出序列总和与最大子序列和之间的差值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

记得开 LL、

#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll n, m, k;
ll a[100010];
ll tot;//记录总和

ll sum[100010] = {0};
//记录k项的和
//如果i<=k 直接用前缀和将这一项加进来。
//如果i>k 就有sum[i] = sum[i - 1] + a[i] - a[i - k];  不停更新数据
ll maxxn = 0;//记录最大值


int main() {
	cin >> n >> k;
	for (int i = 1; i <= n - 1; i++) {
		cin >> a[i];
		tot += a[i];
		if (i > k) {
			sum[i] = sum[i - 1] + a[i] - a[i - k];
		} else
			sum[i] = sum[i - 1] + a[i];

		maxxn = max(maxxn, sum[i]);
	}

	cout << tot - maxxn;



}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值