codeforces 442C C. Artem and Array(有深度的類比)

來源:互聯網
上載者:User

標籤:style   blog   http   color   os   io   資料   for   

題目

 

感謝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;}
View Code

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.