문제
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 복사
ZZZZZ 36
예제 출력 1 복사
60466175
정답 코드
num_list = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"
N, B = input().split()
answer = 0
for i, num in enumerate(N[::-1]):
answer += int(B) ** i * num_list.index(num)
print(answer)
설명
1. 진법을 변환하기 위한 num_list 설정
2. N,B를 통해 입력받기
3. answer을 통해 구하려는 진법의 값을 받을 수 있는 변수 설정
4. 반복문 설정
4-1. 이때 N[::-1]을 하는 이유는 ZZZZZ가 입력된다고 하면 제일 앞에 있는 Z가 36**4*35를 받아야하기 때문
5. 출력
'알고리즘' 카테고리의 다른 글
백준 파이썬 - 2903 (1) | 2024.01.30 |
---|---|
백준 파이썬 - 2720 (1) | 2024.01.29 |
백준 파이썬 - 2563 (0) | 2024.01.24 |
백준 파이썬 - 10798 (0) | 2024.01.19 |
백준 파이썬 - 2566 (0) | 2024.01.19 |