# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
420078 | maximath_1 | 비교 (balkan11_cmp) | C++11 | 2068 ms | 102172 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "cmp.h"
using namespace std;
int cnt = 0;
void remember(int n){
n += 4096;
for(; n > 1; n >>= 2, cnt ++)
bit_set(n);
}
int compare(int a){
a += 4096;
int lf = 0, rg = 6, gt = -1;
for(int md; lf <= rg;){
md = (lf + rg) >> 1;
if(md != 6 && !bit_get(a >> (md * 2))){
gt = a >> (md * 2);
lf = md + 1;
}else rg = md - 1;
}
if(gt == -1) return 0;
if(gt % 4 == 0) return -1;
else if(gt % 4 == 1) return bit_get(gt / 4 * 4) ? 1 : -1;
else if(gt % 4 == 2) return bit_get(gt / 4 * 4 + 3) ? -1 : 1;
else return 1;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |