#include <iostream>
#include <cstdio>
#include <memory.h>
long* tabCoins;
long nSize = 201718/24 + 2;
long maxRow, nRow, nPos = 0L;
#define DIVI 0x00FFFFFFL
#define DIVI2 0x01000000L
#define DIVINE 24L
void insertCoin(long nextCoin)
{
nRow = nextCoin / DIVINE;
tabCoins[nRow] += 1L << (nextCoin % DIVINE);
while(tabCoins[nRow] & DIVI2)
{
tabCoins[nRow] &= DIVI;
++nRow;
tabCoins[nRow] += 1L;
}
if(nRow > maxRow)
maxRow = nRow;
}
long checkMaxPos()
{
long maxPos = 0L;
long mask = 1L;
for(long pos = 0L; pos < DIVINE; ++pos, mask <<= 1)
{
if(tabCoins[maxRow] & mask)
maxPos = pos;
}
return maxRow * DIVINE + maxPos;
}
int main() {
long nCoins = 0L;
long nValue = 0L;
scanf("%ld\n", &nCoins);
tabCoins = new long[nSize];
memset(tabCoins, 0L, nSize * sizeof(long));
while(nCoins--)
{
scanf("%ld", &nValue);
insertCoin(nValue);
}
long res = checkMaxPos();
printf("%ld\n", res);
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 52 53 54 55 56 57 58 | #include <iostream> #include <cstdio> #include <memory.h> long* tabCoins; long nSize = 201718/24 + 2; long maxRow, nRow, nPos = 0L; #define DIVI 0x00FFFFFFL #define DIVI2 0x01000000L #define DIVINE 24L void insertCoin(long nextCoin) { nRow = nextCoin / DIVINE; tabCoins[nRow] += 1L << (nextCoin % DIVINE); while(tabCoins[nRow] & DIVI2) { tabCoins[nRow] &= DIVI; ++nRow; tabCoins[nRow] += 1L; } if(nRow > maxRow) maxRow = nRow; } long checkMaxPos() { long maxPos = 0L; long mask = 1L; for(long pos = 0L; pos < DIVINE; ++pos, mask <<= 1) { if(tabCoins[maxRow] & mask) maxPos = pos; } return maxRow * DIVINE + maxPos; } int main() { long nCoins = 0L; long nValue = 0L; scanf("%ld\n", &nCoins); tabCoins = new long[nSize]; memset(tabCoins, 0L, nSize * sizeof(long)); while(nCoins--) { scanf("%ld", &nValue); insertCoin(nValue); } long res = checkMaxPos(); printf("%ld\n", res); return 0; } |
English