Advertisement
Guest User

Untitled

a guest
Feb 1st, 2013
121
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.82 KB | None | 0 0
  1. #include <algorithm>
  2. #include <cmath>
  3. #include <iostream>
  4. #include <list>
  5. #include <set>
  6. #include <utility>
  7. #include <vector>
  8.  
  9. using namespace std;
  10.  
  11. struct ak {
  12.   long long k;
  13.   long long a;
  14. };
  15.  
  16. int main() {
  17.  
  18.   int n;
  19.   cin >> n;
  20.   vector<ak> data(n);
  21.  
  22.   for(int i = 0; i < n; i++) {
  23.     cin >> data[i].k;
  24.     cin >> data[i].a;
  25.   }
  26.  
  27.   //From max to min
  28.   sort(data.begin(), data.end(), [](const ak &a, const ak &b){return a.k > b.k;});
  29.  
  30.   long long r = data[0].k + 1;
  31.   bool allok = false;
  32.  
  33.   while(!allok) {
  34.     allok = true;
  35.     for(int i = 0; i < n; i++) {
  36.       ak cur = data[i];
  37.       double new_r = log(cur.a)/log(4);
  38.       if( (r-cur.k) < new_r ) {
  39.         allok = false;
  40.         r = (new_r > (r+1) ? new_r : r+1);
  41.         break;
  42.       }
  43.     }
  44.   }
  45.  
  46.   cout << r;
  47.  
  48.   return 0;
  49. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement