Tiny Bunny
본문 바로가기

programmers

프로그래머스 2단계 : 124 나라의 숫자 (Java 자바)

728x90

 

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

문제 설명


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

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

 

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

 

 

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

 

 

제한사항

 

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

 

입출력 예

 

 

 

 

풀이

 

자연수 n을 124 나라의 숫자로 변환하는 문제입니다.

 

1. 10진법 숫자 n을 124 나라의 숫자로 변환

 

2. 124 나라에서는 1, 2, 4만 사용되므로, 10진법의 숫자를 3진법처럼 생각하여 변환

 

3. 주어진 자연수 n을 3으로 나누어 나머지가 0일 때와 아닐 때를 처리하여 124 나라의 숫자로 변환하고,

 

4. 결과 문자열 answer에 앞쪽에 숫자를 계속 추가

 

class Solution {
    public String solution(int n) {
        String answer = ""; // 결과를 저장할 문자열 초기화
        int[] country = { 0, 1, 2, 4 }; // 124 나라에서 사용되는 숫자 패턴

        while (n > 0) { // n이 양수인 동안 반복
            if (n % 3 == 0) { // n이 3으로 나누어 떨어질 때 (나머지가 0)
                answer = Integer.toString(country[3]).concat(answer); // "4"를 결과 문자열 앞에 추가
                n = n / 3 - 1; // n을 3으로 나누고 1을 뺌
            } else {
                answer = Integer.toString(country[n % 3]).concat(answer); // 1, 2, 4 중 하나를 결과 문자열 앞에 추가
                n /= 3; // n을 3으로 나눔
            }
        }
        return answer; // 최종 결과 문자열 반환
    }
}
728x90