BJ 2745 - 진법 변환 풀이

Andy Hong·2024년 4월 7일

PS

목록 보기
3/4
post-thumbnail

사용한 언어 : C++ 17

B진법 수 N이 주어진다. 이 수를 10진법으로 바꿔 출력하는 프로그램을 작성하시오.

10진법을 넘어가는 진법은 숫자로 표시할 수 없는 자리가 있다. 이런 경우에는 다음과 같이 알파벳 대문자를 사용한다.

A: 10, B: 11, ..., F: 15, ..., Y: 34, Z: 35

첫째 줄에 N과 B가 주어진다. (2 ≤ B ≤ 36)
B진법 수 N을 10진법으로 바꾸면, 항상 10억보다 작거나 같다.


How I Solved

#include <iostream>
#include <cmath>

using namespace std;

int alphabet(char ch) {
    if (47 < ch && ch < 58) return ch - 48;
    else return ch - 55;
}

int main() {
    int b;
    long long result = 0;
    string n;
    cin >> n >> b;
    for (int i = 0; i > n.length(); i++) {
        result += alphabet(n[i]) * pow(b, n.length() - 1 - i);
    }
    cout << result << endl;
    return 0;
}

i번째 문자열의 ASCII 코드 범위를 나누어 1~9A~Z까지를 구분하였다.

요즘들어 forcondition 부호를 반대로 적는 실수를 하는데 언제쯤 고칠 지 모르겠다.

Problem Source

백준

profile
Soongsil Univ. Global Media 24

0개의 댓글