Submission #305513

# Submission time Handle Problem Language Result Execution time Memory
305513 2020-09-23T12:08:30 Z danitro XORanges (eJOI19_xoranges) C++14
0 / 100
1000 ms 6532 KB
#include <bits/stdc++.h>
using namespace std;

#define MAX 4 * 2100000

int n, q, a, e, w, trr[MAX], trl[MAX];

vector<int> ll, rr;

void buil(int v, int l, int r)
{
	//cout << l << " " << r << endl;
	if(l == r)
	{
		if(r < int(ll.size()))trl[v] = ll[r];
		return;
	}	
	int mid = (l + r) / 2;
	buil(v * 2, l, mid);
	buil(v * 2 + 1, mid + 1, r);
	trl[v] = trl[v * 2] ^trl[v * 2 + 1];
	return; 
}

void buir(int v, int l, int r)
{
	if(l == r)
	{
		if(l < int(rr.size()))trr[v] = rr[l];
		return;
	}	
	int mid = (l + r) / 2;
	buir(v * 2, l, mid);
	buir(v * 2 + 1, mid + 1, r);
	trr[v] = trr[v * 2] ^trr[v * 2 + 1];
	return; 
}

int qur(int v, int l, int r, int ql, int qr)
{
	if(l > qr || r < ql)return 0;
	if(l >= ql && r <= qr)
	{
	//	cout << l << " " << r << "  "<< v << " " << trr[v] << "  " << trr[v * 2] << "  " << trr[v * 2 + 1]<< endl;
		return trr[v];
	}
	int mid = (l + r) / 2;
	return qur(v * 2, l, mid, ql, qr) ^ qur(v * 2 + 1, mid + 1, r, ql, qr);
}

int qul(int v, int l, int r, int ql, int qr)
{
	
	if(l > qr || r < ql)return 0;
	if(l >= ql && r <= qr)return trl[v];
	int mid = (l + r) / 2;
	return qul(v * 2, l, mid, ql, qr) ^ qul(v * 2 + 1, mid + 1, r, ql, qr);
}

void upr(int v, int l, int r, int ql, int val)
{
	if(l > ql || r < ql)return;
	if(l == ql && r == ql)
	{
		
		trr[v] = val;
		return;
	}
	int mid = (l + r) / 2;
	upr(v * 2, l, mid, ql, val);
	upr(v * 2 + 1, mid + 1, r, ql, val);
	trr[v] = trr[v * 2] ^ trr[v * 2 + 1];
}

void upl(int v, int l, int r, int ql, int val)
{
	if(l > ql || r < ql)return;
	if(l == ql && r == ql)
	{
		trl[v] = val;
		return;
	}
	int mid = (l +r) / 2;
	upl(v * 2, l, mid, ql, val);
	upl(v * 2 + 1, mid + 1, r, ql, val);
	trl[v] = trl[v * 2] ^ trl[v * 2 + 1];
}


int main()
{
	cin >> n >> q;
	ll.push_back(0);
	rr.push_back(0);
	for(int i = 1;i <= n; i++)
	{
		cin >> a;
		if(i % 2 == 0)ll.push_back(a);
		else rr.push_back(a);
	}
	
	buil(1, 1, 210000);
	buir(1, 1, 210000);
	
	for(int i = 0; i < q; i++)
	{
		cin >> a >> e >> w;
		if(a == 2)
		{
			if((e - w) % 2 == 1)cout << "0\n";
			else
			{
				if(e % 2 == 0)cout << qul(1, 1, 210000, e / 2, w / 2) << endl;
				else  cout << qur(1, 1, 210000, e / 2  + 1, w / 2 + 1) << endl;
				//cout << e/2 << " " <<  w/2<< endl;
			}
		}
		else
		{
			if(e % 2 == 0)upl(1, 1, 210000, e / 2, w) ;
			else upr(1, 1, 210000, e / 2  + 1, w);
		}
	}
	//cout << trr[0] << endl;
	return 0;
}
# Verdict Execution time Memory Grader output
1 Incorrect 7 ms 2432 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 8 ms 2432 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 7 ms 2432 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1055 ms 6532 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 7 ms 2432 KB Output isn't correct
2 Halted 0 ms 0 KB -