BOJ

백준 2745 - 진법 변환

yanJuicy 2019. 8. 22. 02:06
반응형

문제

 

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

 

2745번: 진법 변환

B진법 수 N이 주어진다. 이 수를 10진법으로 바꿔 출력하는 프로그램을 작성하시오. 10진법을 넘어가는 진법은 숫자로 표시할 수 없는 자리가 있다. 이런 경우에는 다음과 같이 알파벳 대문자를 사용한다. A: 10, B: 11, ..., F: 15, ..., Y: 34, Z: 35

www.acmicpc.net

 

 

풀이

 

입력 받은 B 진법을 10진법으로 바꾸는 문제이다. 주어진 N에 대해서 1의 자리 부터 차례대로 10진수로 변환을 한다.

i의 자리 수가 0~9일 때와 알파벳일때 구분을 해서 변환을 해주면 된다.

 

변환을 한 숫자를 n이라 할 때, n * B^(i - 1) 이 i의 자리 수가 된다. 따라서 이 숫자들을 더해주면 답이 된다.

 

 

코드

 

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
#include <iostream>
#include <string>
 
using namespace std;
 
string N;
int B, result;
 
int main()
{
    cin.tie(0);
    ios::sync_with_stdio(0);
 
    cin >> N >> B;
    
    int temp = 1;
 
    for (int i = N.size() - 1; i >= 0; i--)
    {
        int n;
        if (N[i] >= '0' && N[i] <= '9') n = N[i] - '0';
        else n = N[i] - 'A' + 10;
        
        n *= temp;
        result += n;
        temp *= B;
    }
    
    cout << result;
 
    return 0;
}
 
cs

 

반응형

'BOJ' 카테고리의 다른 글

백준 2667 - 단지번호붙이기  (0) 2019.08.29
백준 11653 - 소인수분해  (0) 2019.08.23
백준 11657 - 타임머신  (0) 2019.08.21
백준 9466 - 텀 프로젝트  (0) 2019.08.19
백준 11279 - 최대 힙  (0) 2019.08.11