본문 바로가기
알고리즘/기초수학

[java 백준]브론즈 1/ 11005번 진법 변환 2

by Meaning_ 2021. 9. 5.
728x90
반응형

https://www.acmicpc.net/problem/11005

 

11005번: 진법 변환 2

10진법 수 N이 주어진다. 이 수를 B진법으로 바꿔 출력하는 프로그램을 작성하시오. 10진법을 넘어가는 진법은 숫자로 표시할 수 없는 자리가 있다. 이런 경우에는 다음과 같이 알파벳 대문자를

www.acmicpc.net

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import java.io.IOException;
import java.util.Scanner;
 
public class Main {
 
    public static void main(String[] args) throws IOException {
        Scanner sc = new Scanner(System.in);
        char[] arr = new char[36];
        StringBuilder sb = new StringBuilder();
 
        int num = sc.nextInt();
        int slice = sc.nextInt();
        int i = 0;
 
        while (num > 0) {
 
            int strNum = num % slice;
            if (strNum < 10) {
                arr[i] = ((char) (strNum + '0'));// 숫자
            } else {
                arr[i] = ((char) (strNum - 10 + 'A'));
            }
 
            num /= slice;
            i++;
 
        }
 
        for (int j = i; j >= 0; j--) {
            sb.append(arr[j]);
        }
 
        System.out.println(sb.toString().trim());
 
    }
 
}
cs

 

60466175을 36으로 나눴을 때 나머지가 35가 나오기 때문에 z가 출력된다. 몫이 0이될때 까지 나머지의 범위에 따라 알파벳 또는 숫자를 출력해주면된다. 다만 주의깊게 봐야할 부분은  예를 들어 2 2를 넣었을 때 10 이 나와야 하므로 

for (int j = i; j >= 0; j--) {

            sb.append(arr[j]);

        }

--> 이 코드를 통해 01 이 나오는 걸 10으로 뒤집어주면 된다 !

728x90
반응형

댓글