【洛谷】P2367 语文成绩 题解

题目背景

语文考试结束了,成绩还是一如既往地有问题。

题目描述

语文老师总是写错成绩,所以当她修改成绩的时候,总是累得不行。她总是要一遍遍地给某些同学增加分数,又要注意最低分是多少。你能帮帮她吗?

输入格式

第一行有两个整数 nn,pp,代表学生数与增加分数的次数。

第二行有 nn 个数,a_1 \sim a_na1an,代表各个学生的初始成绩。

接下来 pp 行,每行有三个数,xx,yy,zz,代表给第 xx 个到第 yy 个学生每人增加 zz 分。

输出格式

输出仅一行,代表更改分数后,全班的最低分。

 

 思路:如何评价差分板子

ac代码

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
long long sum,i,op[10000090],zop[10000090],cn,x,y,z,minn=300;
int main()
{
	cin>>sum>>cn;
	for(i=1;i<=sum;i++)
	cin>>op[i];
	for(i=1;i<=sum;i++)
	zop[i]=op[i]-op[i-1];
	for(i=0;i<cn;i++)
	{
		cin>>x>>y>>z;
		zop[x]+=z;
		zop[y+1]-=z;
	}
	for(i=1;i<=sum;i++)
	{
		op[i]=op[i-1]+zop[i];
		if(op[i]<minn)
		minn=op[i];
	}
	cout<<minn<<endl;
	return 0;
}

posted on 2022-03-08 21:39  zesure  阅读(328)  评论(0编辑  收藏  举报

导航