#include <iostream> #include <vector> using namespace std; int main() { vector<int> vec(200021, 0); int n; int i; cin >> n; while(n--) { cin >> i; int idx = i/32; i%=32; int b = 1; b<<=(i-1); if(!(vec[idx] & b)) { vec[idx]^=b ; continue; } while(vec[idx] & b) { vec[idx]^=b ; b<<=1; if(b == 0) { ++idx; b=1; } } vec[idx]^=b; } auto it = vec.end(); while(*(--it)==0); int j = 0; do { (*it)>>=1; ++j; } while(*it); cout << (distance(vec.begin(), it))*32+j << endl;; 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 | #include <iostream> #include <vector> using namespace std; int main() { vector<int> vec(200021, 0); int n; int i; cin >> n; while(n--) { cin >> i; int idx = i/32; i%=32; int b = 1; b<<=(i-1); if(!(vec[idx] & b)) { vec[idx]^=b ; continue; } while(vec[idx] & b) { vec[idx]^=b ; b<<=1; if(b == 0) { ++idx; b=1; } } vec[idx]^=b; } auto it = vec.end(); while(*(--it)==0); int j = 0; do { (*it)>>=1; ++j; } while(*it); cout << (distance(vec.begin(), it))*32+j << endl;; return 0; } |