This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <stdio.h>
#include <algorithm>
#define ffs(a) __builtin_ffs(a)
using namespace std;
typedef long long LL;
int a[18][100010];
LL dfs(int p,int A[],int an,int w){
int i,j,k,v,z;
LL mn=102345678900000L;
if(an==1){
if(A[0]<=1)return A[0]*10;
v=A[0]&1022;
mn=(ffs(v)-1)*(A[0]&1? 10:1);
for(v-=v&-v;v;v-=v&-v)mn=mn*10+ffs(v)-1;
return mn;
}
for(i=0;i<=9-w;++i){
k=i,v=z=0;
int *B=a[p+1],bn=0;
for(j=0;j<an;++j){
v|=A[j]^(A[j]&(1<<k));
if(A[j]&1&&!k)z=1;
k=(k+1)%10;
if(!k||j+1==an){
B[bn++]=v;
v=0;
}
}
LL rv=dfs(p+1,B,bn,i==9&&an<=2)*10+i;
if(!rv&&z)rv=10;
mn=min(mn,rv);
}
return mn;
}
int main(){
int i,k,an=0,v;
scanf("%d",&k);
for(i=1;i<=k;++i){
scanf("%d",&v);
a[0][an++]=1<<v;
}
printf("%lld",dfs(0,a[0],an,0));
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |