728x90
문제
10진법 수 N이 주어진다. 이 수를 B진법으로 바꿔 출력하는 프로그램을 작성하시오.
10진법을 넘어가는 진법은 숫자로 표시할 수 없는 자리가 있다. 이런 경우에는 다음과 같이 알파벳 대문자를 사용한다.
A: 10, B: 11, ..., F: 15, ..., Y: 34, Z: 35
입력
첫째 줄에 N과 B가 주어진다. (2 ≤ B ≤ 36) N은 10억보다 작거나 같은 자연수이다.
출력
첫째 줄에 10진법 수 N을 B진법으로 출력한다.
코드
#include <iostream>
#include <algorithm>
using namespace std;
int main(){
int n, b;
cin >> n >> b;
string b_num;
while (n!=0){
int tmp = n % b;
if (tmp > 9){
tmp = tmp - 10 + 'A';
b_num += tmp;
}
else{
b_num += ('0' + tmp);
}
n/=b;
}
reverse(b_num.begin(), b_num.end());
cout << b_num << '\n';
return 0;
}
풀이
이번주에 코테 잡힌게 python이 안되어서 망했다.
그래도 문법 기억해내면서 풀어보는중 ㅠㅠ
10미만까지는 그냥 수를 진법으로 나눈 자리 수를 리턴
10이상부터는 -10 하고 'A' 부터 시작..
최종적으로 거꾸로 출력해야한다.
'알고리즘 문제 풀이 > 백준' 카테고리의 다른 글
[백준] 14503 로봇 청소기 python (0) | 2022.03.18 |
---|---|
[백준] 14891 톱니바퀴 python (0) | 2022.03.17 |
[백준] 11041 플로이드 python (0) | 2022.03.14 |
[백준] 14502 연구소 python (0) | 2022.03.14 |
[백준] 12865 평범한 배낭 python (0) | 2022.03.13 |