Status ¶
| Problem | 2453 | User | talin0528 |
| Memory | 3656K | Time | 375MS |
| Language | Java | Result | Accepted |
Idea ¶
bit , 10 -> 2 변 배 (내 대..;ㅁ;..런 !)
1란 를 0면 1 보내, 1면 맨 보내는...
ex)
0010 0000 -> 0100 0000
0011 1100 -> 0100 0111
1란 를 0면 1 보내, 1면 맨 보내는...
ex)
0010 0000 -> 0100 0000
0011 1100 -> 0100 0111
Source Code ¶
import java.util.Scanner;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
while(sc.hasNextInt()){
int i = sc.nextInt();
if(i == 0)
break;
printJ(i);
}
}
private static void printJ(int i){
int [] bin = binI(i);
int num = 0, count=0;
while(num<bin.length-1){
if(bin[num] == 1){
if(bin[num+1] == 0){
bin[num+1] = 1;
bin[num] = 0;
break;
}else{
bin[num] = 0;
bin[count++] = 1;
}
}
num++;
}
int result = 0;
for(int k=0; k<bin.length;k++){
result += bin[k]*Math.pow(2,k);
}
System.out.println(result);
}
private static int [] binI(int i){
int [] temp = new int [21];
int num = 0;
while(i>0){
temp[num++] = i%2;
i = i/2;
}
return temp;
}
}
Trial and error ¶
- Compile error
- "Main" . poj :)
- "Main" . poj :)
- Runtime error
- printJ 내 while(num
num+1 index bound of exception 났.
- printJ 내 while(num
- Wrong answer
- 2^20 = 1048576 1000000보 배 를 20 는데, 1 0 면 보 더 는 를 못. 1~1000000 4 맨 1 ! ;ㅅ; 보 맞 많 poj는 ! 내 바보
- 2^20 = 1048576 1000000보 배 를 20 는데, 1 0 면 보 더 는 를 못. 1~1000000 4 맨 1 ! ;ㅅ; 보 맞 많 poj는 ! 내 바보
| I | 대 | |
| 524288 | 1048576 | 524288 |
| 786432 | 1048577 | 524289 |
| 917504 | 1048579 | 524291 |
| 983040 | 1048583 | 524295 |










