#include <bits/stdc++.h>
using namespace std;
#define ff(i, a, b) for(auto i=(a); i<=(b); ++i)
#define ffr(i, b, a) for(auto i=(b); i>=(a); --i)
#define nl "\n"
#define ss " "
#define sz size()
#define pb emplace_back
#define pf push_front
#define fi first
#define se second
#define ms(a,x) memset(a, x, sizeof (a))
#define re exit(0)
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
typedef vector<int> vi;
typedef vector<ll> vll;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;
typedef vector<pair<int, int> > vpii;
typedef vector<pair<ll, ll> > vpll;
const ll mod=1e9+7, maxn=3e5+5, inf=1e18;
void rf(){
ios_base::sync_with_stdio(false);
cin.tie(nullptr); cout.tie(nullptr);
if(fopen("o.inp","r")){
freopen("o.inp","r",stdin); freopen("o.out","w",stdout);
}
}
int n, q, a[maxn], f[5005][5005];
int main()
{
rf();
cin>>n>>q;
ff(i, 1, n) cin>>a[i];
ff(i, 1, n) ff(j, i, n) ff(k, i, j) f[i][j]^=a[k];
while(q--)
{
int op, l, r; cin>>op>>l>>r;
if(op==1) a[l]=r;
else
{
if(n<=100)
{
int ans=0;
ff(i, l, r) ff(j, i, r) ff(k, i, j) ans^=a[k];
cout<<ans<<nl;
}
else if(n<=500)
{
int ans=0;
ff(i, l, r) ff(j, i, r) ans^=f[i][j];
cout<<ans<<nl;
}
}
}
re;
}
Compilation message
xoranges.cpp: In function 'void rf()':
xoranges.cpp:32:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
32 | freopen("o.inp","r",stdin); freopen("o.out","w",stdout);
| ~~~~~~~^~~~~~~~~~~~~~~~~~~
xoranges.cpp:32:44: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
32 | freopen("o.inp","r",stdin); freopen("o.out","w",stdout);
| ~~~~~~~^~~~~~~~~~~~~~~~~~~~
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
2908 KB |
Output is correct |
2 |
Correct |
1 ms |
2908 KB |
Output is correct |
3 |
Correct |
1 ms |
2908 KB |
Output is correct |
4 |
Correct |
4 ms |
2916 KB |
Output is correct |
5 |
Correct |
4 ms |
2908 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
14 ms |
4956 KB |
Output is correct |
2 |
Correct |
14 ms |
5024 KB |
Output is correct |
3 |
Correct |
15 ms |
5024 KB |
Output is correct |
4 |
Correct |
37 ms |
5004 KB |
Output is correct |
5 |
Correct |
36 ms |
4996 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
2908 KB |
Output is correct |
2 |
Correct |
1 ms |
2908 KB |
Output is correct |
3 |
Correct |
1 ms |
2908 KB |
Output is correct |
4 |
Correct |
4 ms |
2916 KB |
Output is correct |
5 |
Correct |
4 ms |
2908 KB |
Output is correct |
6 |
Correct |
14 ms |
4956 KB |
Output is correct |
7 |
Correct |
14 ms |
5024 KB |
Output is correct |
8 |
Correct |
15 ms |
5024 KB |
Output is correct |
9 |
Correct |
37 ms |
5004 KB |
Output is correct |
10 |
Correct |
36 ms |
4996 KB |
Output is correct |
11 |
Execution timed out |
1071 ms |
7396 KB |
Time limit exceeded |
12 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Execution timed out |
1027 ms |
3024 KB |
Time limit exceeded |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
2908 KB |
Output is correct |
2 |
Correct |
1 ms |
2908 KB |
Output is correct |
3 |
Correct |
1 ms |
2908 KB |
Output is correct |
4 |
Correct |
4 ms |
2916 KB |
Output is correct |
5 |
Correct |
4 ms |
2908 KB |
Output is correct |
6 |
Correct |
14 ms |
4956 KB |
Output is correct |
7 |
Correct |
14 ms |
5024 KB |
Output is correct |
8 |
Correct |
15 ms |
5024 KB |
Output is correct |
9 |
Correct |
37 ms |
5004 KB |
Output is correct |
10 |
Correct |
36 ms |
4996 KB |
Output is correct |
11 |
Execution timed out |
1071 ms |
7396 KB |
Time limit exceeded |
12 |
Halted |
0 ms |
0 KB |
- |