# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
199037 | TadijaSebez | Swap (BOI16_swap) | C++11 | 76 ms | 6904 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
void ckmn(int &a,int b){a=min(a,b);}
const int N=400050;
int a[N],t[N],ans[N];
int Get(int i){
int ans=1e9;
for(;i;i>>=1){
if(t[i]!=1)ckmn(ans,a[i]);
if(t[i]==0)break;
if((i&1) && t[i^1]!=0){
ckmn(ans,a[i^1]);
if(t[i^1]==1)break;
}
}
return ans;
}
void Set(int i,int f){
for(;i;i>>=1){
if(a[i]==f){
t[i]=0;
break;
}
if(i&1){
if(a[i^1]==f){
t[i]=t[i^1]=1;
break;
}else t[i^1]=0;
}
t[i]=1;
}
}
int main(){
int n;
scanf("%i",&n);
for(int i=1;i<=n;i++)scanf("%i",&a[i]),t[i]=2;
t[1]=0;
for(int i=n+1;i<=n*2+1;i++)a[i]=1e9;
for(int i=1;i<=n;i++){
int gt=Get(i);
ans[i]=min({a[i<<1],a[i<<1|1],gt});
if(ans[i]==gt)
t[i<<1]=0,
t[i<<1|1]=0,
Set(i,gt);
if(ans[i]==a[i<<1])
t[i<<1]=1,
t[i<<1|1]=0;
if(ans[i]==a[i<<1|1])
t[i<<1|1]=1;
}
for(int i=1;i<=n;i++)printf("%i%c",ans[i],i==n?'\n':' ');
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... |