加数ci<2^30,所以如果加数和大于2^30,则一定有组合可以构成2^30
注意这里和一般加法不同,一般的如234+567,而这里就好比 只允许加上1,10,100。。。而不允许加上567这样的数字
然后就是找到这样的组合,这里从大到小排列这些ci,初始sum=2^30,如果ci<sum就取,sum-=ci
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e5+10;

struct Good{
    ll k,no;
};

Good good[N];
ll t,m,ans[N],sum,v,bag;

bool cmp(Good a,Good b){
    return a.k>b.k;
}

int main(){
    cin>>t;
    for(int i=0;i<t;i++){
        memset(ans,0,sizeof ans);
        sum=0;
        cin>>m;
        for(int j=0;j<m;j++){
            cin>>good[j].k;
            good[j].no=j;
            sum+=1<<good[j].k;
        }
        if(sum<(1<<30)) cout<<"impossible"<<endl;
        else {
            sort(good,good+m,cmp);
            bag=1<<30;
            for(int j=0;j<m;j++){
                v=1<<good[j].k;
                if(v<=bag){
                    bag-=v;
                    ans[good[j].no]=1;
                }
            }
            for(int j=0;j<m;j++){
                cout<<ans[j];
            }cout<<endl;
        }
    }
    return 0;
}

创作不易,点赞再走