가위 바위 보
2024. 7. 30. 18:00ㆍ코딩테스트 입문
https://school.programmers.co.kr/learn/courses/30/lessons/120839
문제 설명
가위는 2 바위는 0 보는 5로 표현합니다. 가위 바위 보를 내는 순서대로 나타낸 문자열 rsp가 매개변수로 주어질 때, rsp에 저장된 가위 바위 보를 모두 이기는 경우를 순서대로 나타낸 문자열을 return하도록 solution 함수를 완성해보세요.
제한사항
- 0 < rsp의 길이 ≤ 100
- rsp와 길이가 같은 문자열을 return 합니다.
- rsp는 숫자 0, 2, 5로 이루어져 있습니다.
입출력 예
rsp | result |
"2" | "0" |
"205" | "052" |
입출력 예 설명
입출력 예 #1
- "2"는 가위이므로 바위를 나타내는 "0"을 return 합니다.
입출력 예 #2
- "205"는 순서대로 가위, 바위, 보이고 이를 모두 이기려면 바위, 보, 가위를 순서대로 내야하므로 “052”를 return합니다.
가위바위보를 담은 문자열이 들어오면 항상 이기는 경우를 반환하는 문제입니다.
가위바위보는 가위 > 보 > 바위 > 가위 순으로 이기는 경우가 명확하기 때문에, 딕셔너리로 이기는 경우를 각각 설정할 수 있습니다.
이번에는 딕셔너리를 사용해서 문제를 풀어보겠습니다.
def solution(rsp):
# 가위 - 바위 - 보 딕셔너리 설정
psr = {"0": "5", "2": "0", "5": "2"}
# rsp의 값들마다 승리하는 값들을 딕셔너리에서 추출
answer = ''.join([psr[h] for h in rsp])
return answer
간단한 딕셔너리 활용 문제입니다.