TakahiroNakamori

TakahiroNakamori

中森崇博(ナカモリタカヒロ)

12 /
01
2021
 

Range Xor Query

問題

F – Range Xor Query
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

ポイント

  1. セグメントツリー。

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 60;
// const int INF = 1001001001;

int op(int x, int y) {
  return x ^ y;
}

int e() {
  return 0;
}

int main() {
  int N, Q;
  cin >> N >> Q;

  segtree<int, op, e> seg(N);

  vector<ll> A(N);
  rep(i, N) {
    cin >> A[i];
    seg.set(i, A[i]);
  }

  while(0 < Q) {
    int T, X, Y;
    cin >> T >> X >> Y;
    X--;
    if(T == 1) {
      seg.set(X, seg.get(X) ^ Y);
    } else {
      ll ans = seg.prod(X, Y);
      cout << ans << endl;
    }
    Q--;
  }

  return 0;
}