Codeforces Educational Round #42

终于上紫了qaq
算是省选前的一个好消息了吧qaq
值得纪念。4.10-4.11

CF962A Equator(模拟)

#include 
#include 
#include 
#include 
using namespace std;
#define ll long long
#define inf 0x3f3f3f3f
#define N 200010
inline char gc(){
    static char buf[1<<16],*S,*T;
    if(S==T){T=(S=buf)+fread(buf,1,1<<16,stdin);if(T==S) return  EOF;}
    return *S++;
}
inline int read(){
    int x=0,f=1;char ch=gc();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=gc();}
    while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=gc();
    return x*f;
}
int n,a[N];ll sum=0,tmp=0;
int main(){
//  freopen("a.in","r",stdin);
    n=read();for(int i=1;i<=n;++i) a[i]=read(),sum+=a[i];
    for(int i=1;i<=n;++i){
        tmp+=a[i];if(tmp*2>=sum){printf("%d\n",i);return 0;}
    }
}

CF962B Students in Railway Carriage(贪心)

#include 
#include 
#include 
#include 
using namespace std;
#define ll long long
#define inf 0x3f3f3f3f
#define N 200010
inline int read(){
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar();
    return x*f;
}
int n,a,b,ans=0,last=0;
char s[N];
int main(){
//  freopen("a.in","r",stdin);
    n=read();a=read();b=read();scanf("%s",s+1);
    for(int i=1;i<=n;++i){
        if(s[i]=='*'){last=0;continue;}if(!a&&!b) break;
        if(last==1){if(b) --b,last=2,++ans;else last=0;continue;}
        if(last==2){if(a) --a,last=1,++ans;else last=0;continue;}
        if(a>b) --a,last=1,++ans;
        else --b,last=2,++ans;
    }printf("%d\n",ans);
    return 0;
}

CF962C Make a Square(爆搜)

#include 
#include 
#include 
#include 
using namespace std;
#define ll long long
#define inf 0x3f3f3f3f
#define N 200010
inline int read(){
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar();
    return x*f;
}
int n,ans=inf,bin[11],a[15],m=0;
char s[15];
void dfs(int x){
    if(x==n+1){
        if(!m) return;int res=0;
        for(int i=1;i<=m;++i) res=res*10+a[i];
        int xx=sqrt(res);if(xx*xx==res) ans=min(ans,n-m);return;
    }dfs(x+1);
    if(s[x]=='0'&&!m) return;
    a[++m]=s[x]-'0';dfs(x+1);--m;
}
int main(){
//  freopen("a.in","r",stdin);
    scanf("%s",s+1);n=strlen(s+1);
    dfs(1);if(ans==inf) puts("-1");
    else printf("%d\n",ans);
    return 0;
}

CF962D Merge Equals(stl)

其实就按输入顺序合并就好了qaq,开个map即可。

#include 
#include 
#include 
#include 
using namespace std;
#define ll long long
#define inf 0x3f3f3f3f
#define N 150010
inline char gc(){
    static char buf[1<<16],*S,*T;
    if(S==T){T=(S=buf)+fread(buf,1,1<<16,stdin);if(T==S) return  EOF;}
    return *S++;
}
inline int read(){
    int x=0,f=1;char ch=gc();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=gc();}
    while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=gc();
    return x*f;
}
int n,m;ll a[N];
mapint>mp;
int main(){
//  freopen("a.in","r",stdin);
    n=read();m=n;
    for(int i=1;i<=n;++i){
        ll x=read();
        while(1){
            int y=mp[x];
            if(!y) break;--m;
            a[y]=0;mp[x]=0;x<<=1;
        }mp[x]=i;a[i]=x;
    }printf("%d\n",m);
    for(int i=1;i<=n;++i){
        if(a[i]) printf("%I64d ",a[i]);
    }return 0;
}

CF962E Byteland, Berland and Disputed Cities(贪心)

我们把同属两方的点称为红点。
我们考虑任意两个相邻的红点,他们之间的白点黑点怎么连。
对于所有白点,我们肯定是贪心地链接最近的一个白点/红点。
黑点同理。然后我们还可以把两个红点连起来,以节省一条白的和一条黑的,贪心取最优即可。
然后还要处理一下开头一段。

#include 
#include 
#include 
#include 
using namespace std;
#define ll long long
#define inf 0x3f3f3f3f
#define N 200010
inline int read(){
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar();
    return x*f;
}
int n,last1=0,last2=0,last0=0;
ll ans=0,a[N];
int main(){
//  freopen("a.in","r",stdin);
    n=read();ll mx1=0,mx2=0;
    for(int i=1;i<=n;++i){
        a[i]=read();char op[5];scanf("%s",op+1);
        if(op[1]=='P'){
            if(!last0){
                if(last1) ans+=a[i]-a[last1];
                if(last2) ans+=a[i]-a[last2];
            }
            else{
                mx1=max(mx1,a[i]-a[last1]);ans+=a[i]-a[last1];
                mx2=max(mx2,a[i]-a[last2]);ans+=a[i]-a[last2];
                if(mx1+mx2>a[i]-a[last0]) ans+=a[i]-a[last0]-mx1-mx2;
            }last1=last2=last0=i;mx1=0;mx2=0;
        }if(op[1]=='B'){if(last1) mx1=max(mx1,a[i]-a[last1]),ans+=a[i]-a[last1];last1=i;}
        else{if(last2) mx2=max(mx2,a[i]-a[last2]),ans+=a[i]-a[last2];last2=i;}
    }printf("%I64d\n",ans);
    return 0;
}

你可能感兴趣的:(codeforces,STL,贪心,模拟,比赛)