제출 #1220027

#제출 시각아이디문제언어결과실행 시간메모리
1220027SolikhaXORanges (eJOI19_xoranges)C++17
55 / 100
1095 ms2744 KiB
//#include <bits/stdc++.h>
#include <iostream>
#include <vector>
#include <list>
#include <map>
#include <set>
#include <deque>
#include <queue>
#include <stack>
#include <bitset>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <cctype>
#include <string>
#include <cstring>
#include <ctime>
#include <random>
#include <chrono>
using namespace std;
#define int long long
#define all(a) a.begin(), a.end()
#define rall(a) a.rbegin(), a.rend()
#define ss second
#define ff first
#define pb push_back 
using ull = unsigned long long;

void solve()
{
  int n, q; cin >> n >> q;
  vector<int> v(n);
  for(int &i : v) cin >> i;

  while(q--){
    int t; cin >> t;
    if(t == 1){
      int i, x; cin >> i >> x;
      v[i - 1] = x;
    }else{
      int l, r; cin >> l >> r;
      int ans = 0;
      if((r - l + 1) % 2){
        for(int i = l - 1; i < r; i += 2) ans ^= v[i];
      }
      cout << ans << endl;
    }
  }
}
 
signed main() {
  cin.tie(nullptr)->sync_with_stdio(false);
  // freopen("input.txt", "r", stdin);
  // freopen("output.txt", "w", stdout);
  int t = 1; //cin >> t;
  while(t--){
    solve();
    cout << endl;
  }
  return 0;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...