码迷,mamicode.com
首页 > 其他好文 > 详细

决斗[雅礼集训 2017 Day10]

时间:2018-01-06 21:01:19      阅读:137      评论:0      收藏:0      [点我收藏+]

标签:nbsp   ati   位置   main   一个   height   insert   ace   idt   

技术分享图片

SOL:我们可以证明,设Sum[x]代表1到X编号的矮人被sum[x]个精灵挑为对手,则Sum[x]-x min的位置和其后一个是没有任何关系的(没有精灵会从这个矮人走向下一个矮人)。

那么我们就把其拆成了单链。贪心就好。

#pragma GCC optimize("O2")
#include<bits/stdc++.h>
#define sight(c) (‘0‘<=c&&c<=‘9‘)
#define N 500031
#define eho(x) for(int j=head[x];j;j=net[j])
inline void read(int &x){
    static char c;
    for (c=getchar();!sight(c);c=getchar());
    for (x=0;sight(c);c=getchar())x=x*10+c-48;
}
using namespace std;
void write(int x) {if (x<10) {putchar(0+x);return;} write(x/10); putchar(0+x%10);}
inline void writeln(int x) {if (x<0) putchar(-),x*=-1; write(x); putchar(\n);}
int a[N],c[N],d[N],g[N],n,t,ans,mn,head[N],net[N],fall[N],tot,sum,k;
inline void add(int x,int y) {fall[++tot]=y; net[tot]=head[x];head[x]=tot;}
bool b[N];
set<int> S;
set<int> ::iterator it;
int main () {
//  freopen("b.in","r",stdin);
    read(n); mn=1e9;
    for (int i=1;i<=n;i++) read(a[i]),g[a[i]]++,add(a[i],i);
    for (int i=1;i<=n;i++) read(c[i]);
    for (int i=1;i<=n;i++) read(d[i]);
    for (int i=1;i<=n;i++) { sum=sum+g[i]; 
      if (mn>sum-i) mn=sum-i,k=i;
    }
    for (int i=1;i<=n;i++) {
        if (++k>n) k=1;
        eho(k) 
         S.insert(d[fall[j]]);
        it=S.upper_bound(c[k]);
        if (it==S.end()) S.erase(*S.begin());
        else ans++,S.erase(*it);
    }
    writeln(ans);
}

 

决斗[雅礼集训 2017 Day10]

标签:nbsp   ati   位置   main   一个   height   insert   ace   idt   

原文地址:https://www.cnblogs.com/rrsb/p/8215157.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!