[프로그래머스] [파이썬] 수 조작하기

[15일차] [코딩테스트] [LV.0]

문제 설명

정수 n과 문자열 control이 주어집니다. control은 “w”, “a”, “s”, “d”의 4개의 문자로 이루어져 있으며, control의 앞에서부터 순서대로 문자에 따라 n의 값을 바꿉니다.

  • “w” : n이 1 커집니다.
  • ”s” : n이 1 작아집니다.
  • “d” : n이 10 커집니다.
  • “a” : n이 10 작아집니다.

위 규칙에 따라 n을 바꿨을 때 가장 마지막에 나오는 n의 값을 return 하는 solution 함수를 완성해 주세요.

제한사항

-100,000 ≤ n ≤ 100,000 1 ≤ control의 길이 ≤ 100,000 control은 알파벳 소문자 “w”, “a”, “s”, “d”로 이루어진 문자열입니다.

입출력 예

ncontrolresult
0“wsdawsdassw”-1

입출력 예 설명

  • 수 n은 control에 따라 다음과 같은 순서로 변하게 됩니다.
  • 0 → 1 → 0 → 10 → 0 → 1 → 0 → 10 → 0 → -1 → -2 → -1
  • 따라서 -1을 return 합니다.

🚀 정답 ⭕

내 풀이


def solution(n, control):
    answer = 0
    for x in control:
        if x == 'w':
            n+=1
        elif x == 's':
            n-=1
        elif x == 'd':
            n+=10
        else:
            n-=10
    return n

다른 사람 풀이


def solution(n, control):
    key = dict(zip(['w', 's', 'd', 'a'], [1,-1,10,-10]))
    return return n + sum([key[x] for x in control])

dict와 zip을 자유자재로 사용할 수 있는 날 이 오기를




🌜 개인 공부 기록용 블로그입니다. 오류나 틀린 부분이 있을 경우 
언제든지 댓글 혹은 메일로 지적해주시면 감사하겠습니다! 😄

맨 위로 이동하기


© 2020. All rights reserved.

따라쟁이