코딩테스트/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