Advertisement
Galebickosikasa

Untitled

Nov 20th, 2020
51
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 0.67 KB | None | 0 0
  1. struct ST {
  2. vector<vector<int>> st;
  3. vector<int> pow;
  4.  
  5. ST () {}
  6.  
  7. ST (vector<int>& v) {
  8. int k = 0;
  9. while ((1<<k) <= sz (v)) ++k;
  10. pow = vector<int> (sz (v) + 1);
  11. st = vector<vector<int>> (k, (vector<int> (sz (v))));
  12. int tmp = 0;
  13. fr (i, sz (v)) {
  14. st[0][i] = v[i];
  15. if ((1<<(tmp + 1)) <= i) ++tmp;
  16. pow[i] = tmp;
  17. }
  18. pow[sz (v)] = k - 1;
  19. fl (j, 1, k) {
  20. fr (i, sz (v)) {
  21. if (i + (1<<(j - 1)) >= sz (v)) continue;
  22. st[j][i] = min (st[j - 1][i], st[j - 1][i + (1<<(j - 1))]);
  23. }
  24. }
  25. }
  26.  
  27. int get (int i, int j) {
  28. if (i > j) swap (i, j);
  29. int k = pow[j - i + 1];
  30. return min (st[k][i], st[k][j - (1<<k) + 1]);
  31. }
  32.  
  33. };
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement