반응형
문제 출처
2745번: 진법 변환
B진법 수 N이 주어진다. 이 수를 10진법으로 바꿔 출력하는 프로그램을 작성하시오. 10진법을 넘어가는 진법은 숫자로 표시할 수 없는 자리가 있다. 이런 경우에는 다음과 같이 알파벳 대문자를
www.acmicpc.net
문제
B진법 수 N이 주어진다. 이 수를 10진법으로 바꿔 출력하는 프로그램을 작성하시오.
10진법을 넘어가는 진법은 숫자로 표시할 수 없는 자리가 있다. 이런 경우에는 다음과 같이 알파벳 대문자를 사용한다.
A: 10, B: 11, ..., F: 15, ..., Y: 34, Z: 35
입력
첫째 줄에 N과 B가 주어진다. (2 ≤ B ≤ 36)
B진법 수 N을 10진법으로 바꾸면, 항상 10억보다 작거나 같다.
출력
첫째 줄에 B진법 수 N을 10진법으로 출력한다.
예제
풀이
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
|
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st;
st = new StringTokenizer(br.readLine());
String str = st.nextToken();
int N = Integer.parseInt(st.nextToken());
int num = 0;
for (int i = 0; i < str.length(); i++){
if ('0' <= str.charAt(i) && str.charAt(i) <= '9'){
num = num*N + ((int)str.charAt(i) - (int)'0');
}
else{
num = num*N + ((int)str.charAt(i) - (int)'A' + 10);
}
}
System.out.println(num);
}
}
|
cs |
반응형
'백준' 카테고리의 다른 글
[백준 / JAVA] 1918번 후위 표기식 (0) | 2021.01.21 |
---|---|
[백준 / JAVA] 1406번 에디터 (0) | 2021.01.20 |
[백준 / JAVA] 1929번 소수 구하기 (0) | 2021.01.08 |
[백준 / JAVA] 5622번 다이얼 (0) | 2021.01.07 |
[백준 / JAVA] 1924번 2007년 (0) | 2021.01.07 |