Advertisement
Guest User

Secret

a guest
Aug 20th, 2018
77
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.09 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. #define f first
  3. #define s second
  4. #define N 1234
  5. #define mid ((a + b)/2)
  6. #include "secret.h"
  7. using namespace std;
  8. typedef pair<int, int> pii;
  9.  
  10. int v[N], tree[4*N], inutil, n, ans[N][N], ini[N];
  11.  
  12. map<pii, int> dp;
  13.  
  14. int S(int a, int b)
  15. {
  16. if(dp[pii(a, b)] != 0) return dp[pii(a, b)];
  17.  
  18. return dp[pii(a, b)] = dp[pii(b, a)] = Secret(a, b);
  19. }
  20.  
  21. void build(int nod, int a, int b)
  22. {
  23. if(b - a <= 1) return;
  24.  
  25. for (int i = mid - 1; i >= a; --i)
  26. if(ans[i][mid] == -1) ans[i][mid] = S(ans[i][i + 1], ans[i + 1][mid]);
  27.  
  28. for (int i = mid + 1; i <= b; ++i)
  29. if(ans[mid][i] == -1) ans[mid][i] = S(ans[mid][i - 1], ans[i - 1][i]);
  30.  
  31. build(2*nod, a, mid), build(2*nod + 1, mid, b);
  32. }
  33.  
  34. int Query(int l, int r)
  35. {
  36. if(r < l) swap(l, r);
  37.  
  38. for(int i = l + 1; i <= r; i++)
  39. {
  40. if(ans[l][i] != -1 && ans[i][r + 1] != -1) return S(ans[l][i], ans[i][r + 1]);
  41. }
  42.  
  43. return ans[l][r + 1];
  44. }
  45.  
  46. void Init(int n_, int A[])
  47. {
  48. n = n_;
  49.  
  50. memset(ans, -1, sizeof ans);
  51.  
  52. for(int i = 0; i < n; i++) v[i] = A[i], ans[i][i + 1] = v[i];
  53.  
  54. build(1, 0, n);
  55. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement