Advertisement
Vince14

/<> 11505 (top down seg tree)

Sep 9th, 2023 (edited)
122
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.88 KB | Source Code | 0 0
  1. #include <iostream>
  2. #include <string>
  3. #include <cstring>
  4. #include <algorithm>
  5. #include <cmath>
  6. #include <vector>
  7. #include <set>
  8. #include <map>
  9. #include <stack>
  10. #include <queue>
  11. #include <deque>
  12. #include <unordered_map>
  13. #include <numeric>
  14. #include <iomanip>
  15. using namespace std;
  16. #define pii pair<long long, long long>
  17. #define ll long long
  18. #define FAST ios_base::sync_with_stdio(false); cin.tie(NULL)
  19. const long long dx[4] = {0, 1, 0, -1}, dy[4] = {1, 0, -1, 0};
  20. const long long dl[2] = {1, -1};
  21. const long long MOD = 1000000007;
  22. const long long MAX = 1000005;
  23. const long long MAXN = 1000005;
  24.  
  25. int N, M , K;
  26. long long arr[MAXN];
  27. long long seg[MAXN * 4];
  28.  
  29.  
  30. long long build(int x, int s, int e){
  31.     if(s == e){
  32.         return seg[x] = arr[s];
  33.     }
  34.      int mid = (s + e)/2;
  35.     return seg[x] = (build(x * 2, s, mid) * build(x * 2 + 1, mid + 1, e)) % MOD;
  36. }
  37.  
  38. void update(int x, int s, int e, int idx, long long val){
  39.     if(idx < s || idx > e) return;
  40.     if(s == e){
  41.         seg[x] = val;
  42.         return;
  43.     }
  44.  
  45.     int mid = (s + e)/2;
  46.     update(x * 2, s, mid, idx, val);
  47.     update(x * 2 + 1, mid + 1, e, idx, val);
  48.     seg[x] = (seg[x * 2] * seg[x * 2 + 1]) % MOD;
  49. }
  50.  
  51. long long query(int x, int s, int e, int a, int b){
  52.     if(a > e || b < s) return 1;
  53.     if(a <= s && e <= b){
  54.         return seg[x];
  55.     }
  56.  
  57.     int mid = (s + e)/2;
  58.     return (query(x * 2, s, mid, a, b) * query(x * 2 + 1, mid + 1, e, a, b)) % MOD;
  59. }
  60.  
  61.  
  62. int main() {
  63.     FAST;
  64.     cin >> N >> M >> K;
  65.     for(int i = 1; i <= N; i++){
  66.         cin >> arr[i];
  67.     }
  68.     build(1, 1, N);
  69.     for(int i = 0; i < M + K; i++){
  70.         int a, b, c;
  71.         cin >> a >> b >> c;
  72.         if(a == 1){
  73.             update(1, 1, N, b, c);
  74.         }
  75.         else{
  76.             cout << query(1, 1, N, b, c) << "\n";
  77.         }
  78.     }
  79. }
  80.  
  81. /*
  82. 5 2 2
  83. 1
  84. 2
  85. 3
  86. 4
  87. 5
  88. 1 3 6
  89. 2 2 5
  90. 1 5 2
  91. 2 3 5
  92.  */
  93.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement