Home > Baekjoon > 감소하는 수

감소하는 수
1 초 512 MB 35.992%

출처 : 감소하는 수

Solution
Python

import sys
input = sys.stdin.readline

from itertools import combinations

if __name__ == '__main__':
    N = int(input())
    # 9876543210 배열에서 나올 수 있는 자릿수는 1~10자리임
    for n in range(1, 11):
        # join 함수로 모든 경우의 수를 튜플에서 문자열로 바꿔주고, 작은 수부터 차례로 커지도록 정렬한다.
        lst = sorted(list(map(''.join, combinations('9876543210', n))))
        # 아직 N번째가 안됐으면, 체크한 감소하는 수 갯수만큼 N의 값을 줄여준다.
        if N >= len(lst): N -= len(lst)
        # 현재 리스트 안에 N번째 감소하는 수가 있으면,
        else:
            # 출력해주고, for 문 밖의 조건문에 안 걸리도록 빼준다.
            print(lst[N])
            N -= len(lst)
            break
    # 만약 for문 다 돌았는데 N이 0보다 크거나 같다면, -1을 출력 (감소하는 수가 없음)
    if N >= 0: print(-1)

문제

음이 아닌 정수 X의 자릿수가 가장 큰 자릿수부터 작은 자릿수까지 감소한다면, 그 수를 감소하는 수라고 한다. 예를 들어, 321과 950은 감소하는 수지만, 322와 958은 아니다. N번째 감소하는 수를 출력하는 프로그램을 작성하시오. 0은 0번째 감소하는 수이고, 1은 1번째 감소하는 수이다. 만약 N번째 감소하는 수가 없다면 -1을 출력한다.

입력

첫째 줄에 N이 주어진다. N은 1,000,000보다 작거나 같은 자연수 또는 0이다.

출력

첫째 줄에 N번째 감소하는 수를 출력한다.

예제 입력 1

18

예제 출력 1

42

예제 입력 2

0

예제 출력 2

0

예제 입력 3

500000

예제 출력 3

-1