이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "bulb.h"
#include <vector>
#include <string.h>
#include <algorithm>
using namespace std;
const int MAXN = 300003;
int dp[MAXN][2][2];
int dfs(int cur, int f, int t, vector<int> &L, vector<int> &R) {
if(cur<0) {
if(t==0) return cur==-1;
return 0;
}
int &ret = dp[MAXN][f][t];
if(ret!=-1) return ret;
ret = 0;
if(!f) {
if(t) {
ret |= max(dfs(L[cur], !f, t, L, R),
dfs(L[cur], f, (t+1)%2, L, R)
);
}
else {
ret |= min(dfs(L[cur], !f, t, L, R),
dfs(L[cur], f, (t+1)%2, L, R)
);
}
}
else {
if(t) {
ret |= max(dfs(L[cur], !f, (t+1)%2, L, R),
dfs(L[cur], f, (t+2)%2, L, R)
);
}
else {
ret |= min(dfs(L[cur], !f, (t+1)%2, L, R),
dfs(L[cur], f, (t+2)%2, L, R)
);
}
}
if(!f) {
if(t) {
ret |= max(dfs(R[cur], !f, (t+1)%2, L, R),
dfs(R[cur], f, (t+2)%2, L, R)
);
}
else {
ret |= min(dfs(R[cur], !f, (t+1)%2, L, R),
dfs(R[cur], f, (t+2)%2, L, R)
);
}
}
else {
if(t) {
ret |= max(dfs(R[cur], !f, t, L, R),
dfs(R[cur], f, (t+1)%2, L, R)
);
}
else {
ret |= min(dfs(R[cur], !f, t, L, R),
dfs(R[cur], f, (t+1)%2, L, R)
);
}
}
return ret;
}
int FindWinner(int T, vector<int> L, vector<int> R){
int N = L.size();
memset(dp, -1, sizeof(dp));
T%=2;
int ans = dfs(0, 0, T, L, R);
return ans==1;
}
컴파일 시 표준 에러 (stderr) 메시지
bulb.cpp: In function 'int FindWinner(int, std::vector<int>, std::vector<int>)':
bulb.cpp:77:6: warning: unused variable 'N' [-Wunused-variable]
int N = L.size();
^
bulb.cpp: In function 'int dfs(int, int, int, std::vector<int>&, std::vector<int>&)':
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
int &ret = dp[MAXN][f][t];
~~~~~~~^
bulb.cpp: In function 'int dfs(int, int, int, std::vector<int>&, std::vector<int>&)':
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
bulb.cpp: In function 'int FindWinner(int, std::vector<int>, std::vector<int>)':
bulb.cpp:17:20: warning: array subscript is above array bounds [-Warray-bounds]
int &ret = dp[MAXN][f][t];
~~~~~~~^
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |