# 문제 설명
가위는 2 바위는 0 보는 5로 표현합니다. 가위 바위 보를 내는 순서대로 나타낸 문자열 rsp가 매개변수로 주어질 때, rsp에 저장된 가위 바위 보를 모두 이기는 경우를 순서대로 나타낸 문자열을 return하도록 solution 함수를 완성해보세요.
제한사항
- 0 < rsp의 길이 ≤ 100
- rsp와 길이가 같은 문자열을 return 합니다.
- rsp는 숫자 0, 2, 5로 이루어져 있습니다.
# 코딩
def solution(rsp):
# 승리 규칙을 딕셔너리로 정의
win = {'2': '0', '0': '5', '5': '2'}
# 각 문자를 변환해서 새로운 문자열 생성
result = ''.join([win[char] for char in rsp])
return result
# 상세설명
1. 리스트 내포(List Comprehension): [win[char] for char in rsp]
- 이 구문은 **리스트 내포(list comprehension)**라는 파이썬의 문법입니다. 리스트 내포는 기존 리스트나 반복 가능한 객체에서 새로운 리스트를 생성하는 간단하고 효율적인 방법입니다.
- for char in rsp: 입력받은 rsp 문자열을 순차적으로 순회하면서 각 문자를 char에 할당합니다.
- win[char]: char가 2, 0, 또는 5일 때, 딕셔너리 win에서 해당 문자의 승리하는 값(예: 2 -> 0, 0 -> 5, 5 -> 2)을 찾아 반환합니다.
- 그 결과로 변환된 문자들을 새로운 리스트에 담습니다.
예를 들어, rsp = "205"일 경우:
- 첫 번째 char는 '2', 따라서 win['2']는 '0'입니다.
- 두 번째 char는 '0', 따라서 win['0']는 '5'입니다.
- 세 번째 char는 '5', 따라서 win['5']는 '2'입니다.
따라서 리스트 내포 결과는 ['0', '5', '2']가 됩니다.
2. ''.join(...): 문자열 결합
- '.join(...): 리스트에 있는 요소들을 하나의 문자열로 합치는 역할을 합니다. '`는 빈 문자열이므로, 리스트의 각 요소를 그대로 붙여서 하나의 문자열로 만듭니다.
- 리스트 ['0', '5', '2']를 문자열 '052'로 변환합니다.
최종 결과:
입력 문자열의 각 문자를 승리하는 값으로 변환하고, 그 결과를 다시 하나의 문자열로 결합하는 과정입니다. 예를 들어:
- 입력: "205"
- 변환된 리스트: ['0', '5', '2']
- 결과 문자열: "052"
따라서 함수는 "205"를 입력받으면 "052"를 반환하게 됩니다.
728x90
'코딩스터디' 카테고리의 다른 글
[프로그래머스]인덱스 바꾸기 파이썬 (0) | 2024.09.23 |
---|---|
[프로그래머스] 주사위의 개수 파이썬 (1) | 2024.09.12 |
[프로그래머스] n의 배수 고르기 파이썬 (2) | 2024.09.06 |
[프로그래머스] 가장 큰 수 찾기 파이썬 (0) | 2024.09.05 |
[프로그래머스] 대문자와 소문자 (1) | 2024.09.04 |