【洛谷】P2367 语文成绩 题解
题目背景
语文考试结束了,成绩还是一如既往地有问题。
题目描述
语文老师总是写错成绩,所以当她修改成绩的时候,总是累得不行。她总是要一遍遍地给某些同学增加分数,又要注意最低分是多少。你能帮帮她吗?
输入格式
第一行有两个整数 nn,pp,代表学生数与增加分数的次数。
第二行有 nn 个数,a_1 \sim a_na1∼an,代表各个学生的初始成绩。
接下来 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;
}