EunGyeongKim

[탐욕법]큰 수 만들기 본문

코딩테스트/programmers

[탐욕법]큰 수 만들기

EunGyeongKim 2022. 10. 13. 18:07

더 많은 코드 (https://github.com/EunGyeongKim/TIL)

 

GitHub - EunGyeongKim/TIL: Today I Learne

Today I Learne. Contribute to EunGyeongKim/TIL development by creating an account on GitHub.

github.com

문제 링크

 

프로그래머스

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

programmers.co.kr

1. 문제 설명

어떤 숫자에서 k개의 수를 제거했을 때 얻을 수 있는 가장 큰 숫자를 구하려 합니다.

예를 들어, 숫자 1924에서 수 두 개를 제거하면 [19, 12, 14, 92, 94, 24] 를 만들 수 있습니다. 이 중 가장 큰 숫자는 94 입니다.

문자열 형식으로 숫자 number와 제거할 수의 개수 k가 solution 함수의 매개변수로 주어집니다. number에서 k 개의 수를 제거했을 때 만들 수 있는 수 중 가장 큰 숫자를 문자열 형태로 return 하도록 solution 함수를 완성하세요.


2. 제한사항

  • number는 2자리 이상, 1,000,000자리 이하인 숫자입니다.
  • k는 1 이상 number의 자릿수 미만인 자연수입니다.

3. 입출력 예

number k return
"1924" 2 "94"
"1231234" 3 "3234"
"4177252841" 4 "775841"
“4321” 1 “432”

4. 코드

def solution(number, k):
    number = list(number)
    target = []
    tmp_k = k

    for i in number:
        # target = []
        if len(target) == 0:
            target.append(i)
            continue

        # print(target, target[-1], i)

        if k > 0 : 
            while target[-1] < i :
                target.pop()
                k -= 1
                if not target or k <= 0:
                    break

        target.append(i)

    return "".join(target[:len(number)-tmp_k])
Comments