#include<iostream> using namespace std; constexpr int MAXN=201718; constexpr int LOGN=18; bool T[MAXN*LOGN]; int main(){ ios_base::sync_with_stdio(0); cin.tie(0); int n,ans=0,x; cin>>n; while(n--){ cin>>x; while(T[x]) T[x++]=false; T[x]=true; ans=max(ans,x); } cout<<ans; return 0; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | #include<iostream> using namespace std; constexpr int MAXN=201718; constexpr int LOGN=18; bool T[MAXN*LOGN]; int main(){ ios_base::sync_with_stdio(0); cin.tie(0); int n,ans=0,x; cin>>n; while(n--){ cin>>x; while(T[x]) T[x++]=false; T[x]=true; ans=max(ans,x); } cout<<ans; return 0; } |