본문 바로가기

코딩스터디

[프로그래머스] 가위 바위 보 파이썬

 

# 문제 설명

가위는 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