# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
115681 | suzy | Bali Sculptures (APIO15_sculpture) | C++17 | 5 ms | 640 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <stdio.h>
#include <string.h>
#include <vector>
#include <algorithm>
using namespace std;
typedef long long lli;
lli a[2001], p[2001];
int n, L, R;
vector<int> con[2001], tmp[2001];
int d1[101][101], d2[2001];
int f1(int c, int k) {
if(k>n) return L<=c && c<=R;
if(d1[c][k]>=0) return d1[c][k];
for(int i=0;i<con[k].size();i++) {
int v=con[k][i];
if(f1(c+1,v+1)) return d1[c][k]=1;
}
return d1[c][k]=0;
}
int f2(int k) {
if(k>n) return 0;
if(d2[k]>=0) return d2[k];
int ret=(1<<30);
for(int i=0;i<con[k].size();i++) {
int v=con[k][i];
ret=min(ret,f2(v+1)+1);
}
return d2[k]=ret;
}
void make(int b) {
for(int i=1;i<=n;i++) {
tmp[i]=con[i];
con[i].clear();
for(int j=0;j<tmp[i].size();j++) {
if((p[tmp[i][j]]-p[i-1])&(1<<b)) continue;
con[i].push_back(tmp[i][j]);
}
}
}
int solve1() {
int ret=0;
for(int b=29;b>=0;b--) {
memset(d1,-1,sizeof(d1));
make(b);
if(f1(0,1)==0) {
for(int i=1;i<=n;i++)
con[i]=tmp[i];
ret|=(1<<b);
}
}
return ret;
}
int solve2() {
int ret=0;
for(int b=29;b>=0;b--) {
memset(d2,-1,sizeof(d2));
make(b);
if(f2(1)>R) {
for(int i=1;i<=n;i++)
con[i]=tmp[i];
ret|=(1<<b);
}
}
return ret;
}
int main() {
scanf("%d %d %d",&n,&L,&R);
for(int i=1;i<=n;i++) {
scanf("%lld",&a[i]);
p[i]=p[i-1]+a[i];
}
for(int i=1;i<=n;i++) {
for(int j=i;j<=n;j++)
con[i].push_back(j);
}
int res;
if(L>1) res=solve1();
else res=solve2();
printf("%d\n",res);
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
# | 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... |