#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <set>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <cmath>
#include <bitset>
#include <fstream>
using namespace std;
#define pi pair<int,int>
#define mp(x,y) make_pair(x,y)
#define fi first
#define se second
#define pl pair<long long,long long>
#define pb push_back
#define vi vector<int>
#define ll long long
const int MAXN=1e6+5, mod=1e9+7;
int t[MAXN];
int main ()
{
int a,b,c,d,e,f,g,z,k,n;
scanf("%d", &n);
while (n--)
{
scanf("%d", &a);
t[a]++;
}
b=0;
for (a=0; a<MAXN; a++)
if (t[a])
{
b=a;
t[a+1]+=t[a]/2;
}
printf("%d", b);
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 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | #include <iostream> #include <cstdio> #include <algorithm> #include <cstring> #include <set> #include <vector> #include <queue> #include <stack> #include <map> #include <cmath> #include <bitset> #include <fstream> using namespace std; #define pi pair<int,int> #define mp(x,y) make_pair(x,y) #define fi first #define se second #define pl pair<long long,long long> #define pb push_back #define vi vector<int> #define ll long long const int MAXN=1e6+5, mod=1e9+7; int t[MAXN]; int main () { int a,b,c,d,e,f,g,z,k,n; scanf("%d", &n); while (n--) { scanf("%d", &a); t[a]++; } b=0; for (a=0; a<MAXN; a++) if (t[a]) { b=a; t[a+1]+=t[a]/2; } printf("%d", b); return 0; } |
English