728x90
https://www.acmicpc.net/problem/1373
메모리: 23,616 KB , 시간: 336 ms
사용 알고리즘: 수학, 문자열
728x90
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws Exception{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
// 2진수 입력
char[] binary = br.readLine().toCharArray();
// 2진수 -> 8진수를 담을 곳
StringBuilder result = new StringBuilder();
int tmp;
for (int i = binary.length - 1; i >= 0; i -= 3) {
tmp = 0;
// 2진수를 3개씩 끊어서 읽으면 8진수가 됨
for (int j = 0; j < 3; j++) {
if(i - j < 0) break;
tmp += (binary[i - j] - '0') * Math.pow(2, j);
}
result.append(tmp);
}
// 2진수를 뒤에서부터 8진수로 바꿔주었기 때문에 답이 뒤집혀 있으므로 반대로 출력
System.out.println(result.reverse());
}
}
728x90
'Problem Solving > BOJ' 카테고리의 다른 글
[백준, BOJ 10610] 30 (java) (0) | 2025.01.07 |
---|---|
[백준, BOJ 3758] KCPC (java) (0) | 2025.01.03 |
[백준, BOJ 2559] 수열 (java) (0) | 2024.12.12 |
[백준, BOJ 2293] 동전 1 (java) (0) | 2024.12.12 |
[백준, BOJ 1357] 뒤집힌 덧셈 (java) (0) | 2024.11.17 |