이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "bits/stdc++.h"
using namespace std;
#define ar array
const int N = 105;
int dp[N][N];
void solve(){
int n, k; cin>>n>>k;
vector<int> a(n);
for(int i=0;i<n;i++) cin>>a[i];
int res = 0;
if(k == 1){
for(int i=0;i<n;i++){
res ^= (a[i] & 1);
}
} else {
//~ for(int i=0;i<n;i++){
//~ res ^= dp[a[i]][min(k, a[i])];
//~ }
while(a[0] && k){
if(a[0] & 1){
cout<<1;
return;
}
k >>= 1;
a[0] >>= 1;
}
}
if(res) cout<<1;
else cout<<0;
}
signed main(){
ios::sync_with_stdio(0); cin.tie(0);
dp[0][0] = 0;
for(int i=1;i<N;i++){
for(int j=1;j<=i;j++){
vector<int> tt;
for(int l=1;l<=j;l++){
tt.push_back(dp[i-l][min(i-l, l)]);
}
sort(tt.begin(), tt.end());
int last = 0;
for(auto x : tt){
if(x > last) break;
if(x == last) last++;
}
dp[i][j] = last;
}
}
int t; cin>>t;
while(t--){
solve();
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |