#include <stdio.h>
int set[925], iota;
void init()
{
for (int i = 1; i < (1<<12); ++i)
if(__builtin_popcount(i) == 6)
set[++iota] = i;
}
int encode(int n,int x,int y)
{
if (!iota) init();
for(int i=0;i<12;++i)
if((set[x]&(1<<i))&&!(set[y]&(1<<i)))
return i+1;
return- 1;
}
int decode (int n, int q, int h)
{
if (!iota) init();
return(set[q]&(1<<(h-1)));
}
#include <stdio.h>
int set[925], iota;
void init()
{
for (int i = 1; i < (1<<12); ++i)
if(__builtin_popcount(i) == 6)
set[++iota] = i;
}
int encode(int n,int x,int y)
{
if (!iota) init();
for(int i=0;i<12;++i)
if((set[x]&(1<<i))&&!(set[y]&(1<<i)))
return i+1;
return- 1;
}
int decode (int n, int q, int h)
{
if (!iota) init();
return(set[q]&(1<<(h-1)));
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
1610 ms |
25212 KB |
wrong answer |
2 |
Incorrect |
1573 ms |
25228 KB |
wrong answer |