题意简述:
有 n n n 个巨人,需要你以某种顺序叠起来。某个巨人只能踩在地面上或者另一个巨人的肩上。现在给定你所有巨人站在地面上时的肩离地面的高度 A i A_i Ai 和头顶离地面的高度 B i B_i Bi,求把所有巨人叠起来后的高度最大值。
题解:
容易发现,每一个巨人的肩高 A i A_i Ai 是一定有贡献的,而总高度比巨人的肩高和多了一个头到肩的距离,所以问题转化为了找头肩差最大的巨人。
代码如下:
#include<bits/stdc++.h>
using namespace std;
int x,y,z,n,maxn;
long long ans;//开longlong
int main(){
cin>>n;
for(int i=1;i<=n;i++){
cin>>x>>y;
maxn=max(y-x,maxn);//找最大值
ans+=x;
}
cout<<ans+maxn;//输出答案
return 0;//完结撒花
}
点个赞再走!