標籤: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