코딩테스트/프로그래머스

124 나라의 숫자 C++[프로그래머스]

멍토 2020. 5. 10.

문제 주소입니다.

https://programmers.co.kr/learn/courses/30/lessons/12899

 

코딩테스트 연습 - 124 나라의 숫자

124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다. 124 나라에는 자연수만 존재합니다. 124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.

programmers.co.kr


1. 문제 설명

2. 문제 해석

3. 소스 코드

4. 결과


1. 문제 설명

124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.

  1. 124 나라에는 자연수만 존재합니다.
  2. 124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.

예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다.

자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요.

 

10진법 124 나라 10진법 124 나라
1 1 6 14
2 2 7 21
3 4 8 22
4 11 9 24
5 12 10 41

제한사항

  • n은 500,000,000이하의 자연수 입니다.

예시

입출력 예

n result
1 1
2 2
3 4
4 11

2. 문제풀이

숫자가 1, 2, 4 밖에 없다고 한다 -> 3진법 계산으로 볼 수 있다.(근데 0을 표현하려면 어떻게 써야할까?)
n = 1 일때  124진법은 1이고 3으로 나눈 나머지 1
n = 2 일때 124진법은 2이고 3으로 나눈 나머지는 2
n = 3일때 124진법은 4이고 3으로 나눈 나머지는 0
배열로 계산하기 쉽게 [4, 1, 2]를 넣어두었다.

이제 n이 없어질때까지 반복을 한다.
주의 : 3과 정확히 나누어 떨어진다면 몫이 1이 생기기때문에 -1을 해줘야 한다.


3. 소스코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <string>
#include <vector>
 
using namespace std;
 
string solution(int n) {
    string answer = "";
    string temp[3]{"4""1""2"};
    while (n) {
        answer = temp[n % 3]+ answer;
        if (!(n % 3))
            n = n / 3 - 1;
        else
            n = n/3;
    }
    return answer;
}

 


4. 결과

댓글

💲 광고입니다.