首页 > 代码库 > codeforces 442C C. Artem and Array(有深度的模拟)
codeforces 442C C. Artem and Array(有深度的模拟)
题目
感谢JLGG的指导!
思路:
//把数据转换成一条折线,发现有凸有凹
//有凹点,去掉并加上两边的最小值
//无凹点,直接加上前(n-2)个的和(升序)
//数据太大,要64位
//判断凹与否,若一边等于,一边大于,那中间这个也算是凹进去的,所以判断时要加上等于
//有凹点,去掉并加上两边的最小值//无凹点,直接加上前(n-2)个的和(升序)//数据太大,要64位//判断凹与否,若一边等于,一边大于,那中间这个也算是凹进去的,所以判断时要加上等于#include<stdio.h>#include<string.h>#include<algorithm>using namespace std;#define ll long long int n,a[500010],b[500010];int main(){ while(scanf("%d",&n)!=EOF) { for(int i=0;i<n;i++) { scanf("%d",&a[i]); } ll ans=0; if(n>2) { int id=0; b[id++]=a[0]; b[id++]=a[1]; for(int i=2;i<n;i++) { while(b[id-1]<=b[id-2]&&b[id-1]<=a[i])//难道是因为没有等于的缘故 { ans+=min(b[id-2],a[i]); id--; } b[id++]=a[i]; } sort(b,b+id); for(int i=0;i<id-2;i++) ans+=b[i]; } printf("%I64d\n",ans); } return 0;}
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。