【正经题解】积木大赛
2024-02-23 10:53:24
发布于:台湾
39阅读
0回复
0点赞
把序列分成( ,.. )( ,... )......( ,... )多个非递减序列。
然后所有段中最大值的和减去除第一段外的段的最小值,化简一下,就出来了
#include <iostream>
using namespace std;
int main()
{
int n,a,last=0,ans=0;
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>a;
if(a>last)ans+=(a-last);
last=a;
}
cout<<ans<<endl;
}
这里空空如也
有帮助,赞一个