Advertisement
smatskevich

Рыцарский турнир

Apr 10th, 2022
1,009
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.74 KB | None | 0 0
  1. #include <algorithm>
  2. #include <cmath>
  3. #include <iostream>
  4. #include <map>
  5. #include <set>
  6. #include <stack>
  7. #include <string>
  8. #include <tuple>
  9. #include <unordered_map>
  10. #include <unordered_set>
  11. #include <vector>
  12.  
  13. typedef long long ll;
  14. using namespace std;
  15.  
  16. // Степень 2, больше либо равная n.
  17. int UpLog2(int n) {
  18.   int k = 0;
  19.   while (1 << k < n) ++k;
  20.   return k;
  21. }
  22.  
  23. // l и r включительно
  24. void fight(vector<int>& t, vector<int>& result, int v, int lx, int rx, int l, int r, int x) {
  25.   if (t[v] >= 0) {  // На данном диапазоне есть победитель
  26.     if (l <= t[v] && t[v] <= r && t[v] != x && result[t[v]] == -1) {  // x – победитель t[v]
  27.       result[t[v]] = x;
  28.       t[v] = x;
  29.     }
  30.     return;
  31.   }
  32.   if (r < lx || rx < l) return;
  33.   // Это точно не лист (иначе t[v] >= 0)
  34.   int mx = (lx + rx) / 2;
  35.   fight(t, result, 2 * v, lx, mx, l, r, x);
  36.   fight(t, result, 2 * v + 1, mx + 1, rx, l, r, x);
  37.   if (l <= lx && rx <= r) {
  38.     t[v] = x;  // Новый победитель диапазона
  39.   }
  40. }
  41.  
  42. int main() {
  43.   ios::sync_with_stdio(false);
  44.   cin.tie(nullptr);
  45.  
  46.   int m = 0, q = 0; cin >> m >> q;
  47.  
  48.   int n = 1 << UpLog2(m);
  49.   std::vector<int> t(2 * n, -1);  // В узлах -1 означает, что победитель еще не определен.
  50.   // Номера победителей в листьях.
  51.   for (int i = 0; i < m; ++i) t[n + i] = i;
  52.   vector<int> result(m, -1);
  53.   for (int i = 0; i < q; ++i) {
  54.     int l, r, x; cin >> l >> r >> x;
  55.     --l; --r; --x;
  56.     fight(t, result, 1, 0, n - 1, l, r, x);
  57.   }
  58.   for (int i = 0; i < m; ++i) {
  59.     cout << result[i] + 1 << " ";
  60.   }
  61.   cout << endl;
  62.  
  63.   return 0;
  64. }
  65.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement