코딩테스트/Programmers Level 1

17일차. 숫자 짝궁

자유로운영혼이다냥 2023. 12. 10. 21:25

숫자 짝

https://school.programmers.co.kr/learn/courses/30/lessons/131128

 

프로그래머스

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

programmers.co.kr

 


 

문제

 


 

풀이과정

가장 큰 수가 되려면 앞에 큰 수가 오고, 뒤에 작은 수가 오는게 좋다.

그러므로 9부터 0까지 갯수를 세고, 그만큼 더해준 다음에 두가지 케이스에대한 예외처리를 해준다.

count가 상당히 무거우니 collections의 Counter를쓰는게 효율면에서는 더 좋다.


 

정답

def solution(X, Y):
    answer = ''
    temp = 0
    for i in map(str, range(9, -1, -1)):
        x = X.count(i)
        y = Y.count(i)
        if x > y:
            temp = y
        else:
            temp = x
        answer += i * temp
    if answer == "":
        return "-1"
    if len(answer) == answer.count("0"):
        return "0"
    return answer