CF165E

这没什么好讲的,都是套路。

话说我的代码在本地跑得贼慢,我还以为会TLE,然后发现时限有4s

看代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=5*1e6+10;
int f[maxn],a[maxn],n,m;
int main(){
    cin>>n;m=22;
    for(int i=1;i<=n;i++){
        scanf("%d",&a[i]);
        f[a[i]]=a[i];
    }
    for(int j=0;j<(1<<m);j++)
        for(int i=0;i<m;i++)
            if((j&(1<<i))&&f[j^(1<<i)]){
                f[j]=f[j^(1<<i)];
                break;
            }
    for(int i=1;i<=n;i++){
        if(!f[(1<<m)-1-a[i]])printf("-1 ");
        else printf("%d ",f[(1<<m)-1-a[i]]);
    }
    puts("");
    return 0;
}

深深地感到自己的弱小。

 

posted @ 2020-03-17 17:25  syzf2222  阅读(193)  评论(0编辑  收藏  举报