#include <iostream> using namespace std; int main () { const int M=201718+22; bool tab[M]; for(int j=0; j<M; j++) tab[j]=0; int n; cin>>n; for(int j=0; j<n; j++) { int a; cin>>a; int t=0; while(tab[a+t]==1) { tab[a+t]=0; t++; } tab[a+t]=1; } for(int j=M-1;j>=0;j--) { if(tab[j]==1) { cout<<j; break; } } return 0; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | #include <iostream> using namespace std; int main () { const int M=201718+22; bool tab[M]; for(int j=0; j<M; j++) tab[j]=0; int n; cin>>n; for(int j=0; j<n; j++) { int a; cin>>a; int t=0; while(tab[a+t]==1) { tab[a+t]=0; t++; } tab[a+t]=1; } for(int j=M-1;j>=0;j--) { if(tab[j]==1) { cout<<j; break; } } return 0; } |