Advertisement
SorahISA

[SPOJ VISBLEBOX] Decreasing Number of Visible Box (multiset)

May 7th, 2020
151
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.59 KB | None | 0 0
  1. // #pragma GCC target("avx2")
  2. #pragma GCC optimize("O3", "unroll-loops")
  3.  
  4. // #include <bits/extc++.h>
  5. // using namespace __gnu_pbds;
  6.  
  7. #include <bits/stdc++.h>
  8. using namespace std;
  9.  
  10. #define int long long
  11. #define double long double
  12. // template <typename T>
  13. // using pbds_set = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>;
  14. using pii = pair<int, int>;
  15. template<typename T>
  16. using prior = priority_queue<T, vector<T>, greater<T>>;
  17. template<typename T>
  18. using Prior = priority_queue<T>;
  19.  
  20. #define X first
  21. #define Y second
  22. #define ALL(x) (x).begin(), (x).end()
  23. #define eb emplace_back
  24. #define pb push_back
  25.  
  26. #define fastIO() ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0)
  27. #define RANDOM() random_device __rd; \
  28.                  mt19937 __gen = mt19937(__rd()); \
  29.                  uniform_int_distribution<int> __dis(0, 1); \
  30.                  auto rnd = bind(__dis, __gen);
  31.  
  32. const int INF = 1E18;
  33. const int mod = 1E9 + 7;
  34.  
  35. void solve() {
  36.     int n, num, piv, ans = 0;
  37.     cin >> n;
  38.    
  39.     multiset<int> st;
  40.     for (int i = 0; i < n; ++i) cin >> num, st.insert(num);
  41.    
  42.     while (st.size() > 0) {
  43.         ++ans, piv = *st.rbegin();
  44.         st.erase(st.find(piv));
  45.        
  46.         while (piv) {
  47.             piv = st.upper_bound(piv/2) != st.begin() ? *prev(st.upper_bound(piv/2)) : 0;
  48.             if (piv) st.erase(st.find(piv));
  49.         }
  50.     }
  51.    
  52.     cout << ans << "\n";
  53. }
  54.  
  55. int32_t main() {
  56. //  fastIO();
  57.    
  58.     int t;
  59.     cin >> t;
  60.     for (int i = 1; i <= t; ++i) printf("Case %d: ", i), solve();
  61.    
  62.     return 0;
  63. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement