Codeforces Round #437 (Div. 2, based on MemSQL Start[c]UP 3.0 - Round 2) E

來源:互聯網
上載者:User

標籤:include   second   const   play   using   而且   沒有   貪心   amp   

題意:減前面的數,加後面的數,保證最後不剩下數,加減次數要相同;

題解:emmmmm,看出是個貪心,先對價值排序,相同就對下標排序,規律是每次找第一個,然後從後往前找沒有使用過的下表比他大的第一個,相減,然後直到找不到為止,

但是這樣的時間複雜度是O(N^2),想了很久還是不知道怎麼用優先隊列來最佳化= =,結果發現別人都不是這個規律做的。。。。,都是直接暴力扔進去,直接減,為了保證減的是最大的,把減過後的數仍兩個到隊列裡,這樣保證了再次減的時候相當於,當前數減了之前那個數,而且把中間數扔進了隊列

#include<bits/stdc++.h>#define fi first#define se second#define mp make_pair#define pb push_back#define read(a) scanf("%d",&a)#define pii pair<int,int>#define C 0.5772156649#define pi acos(-1.0)#define ll long long#define mod 1000000007#define ls l,m,rt<<1#define rs m+1,r,rt<<1|1using namespace std;const double g=10.0,eps=1e-7;const int N=300000+10,maxn=60+10,inf=0x3f3f3f;priority_queue<int,vector<int>,greater<int> >q;int main(){    int n;    read(n);    ll ans=0;    for(int i=0;i<n;i++)    {        int a;        read(a);        if(q.empty()||a<=q.top())q.push(a);        else        {            ans+=a-q.top();            q.pop();            q.push(a);            q.push(a);        }    }    printf("%lld\n",ans);    return 0;}/****************************************/
View Code

 

Codeforces Round #437 (Div. 2, based on MemSQL Start[c]UP 3.0 - Round 2) E

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.