Algorithm/코딩테스트 (Python)

[프로그래머스][딕셔너리(해시맵)] 숫자 문자열과 영단어

싱브이 2023. 11. 6. 21:15
728x90
반응형

문제

네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.

다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.

  • 1478 → "one4seveneight"
  • 234567 → "23four5six7"
  • 10203 → "1zerotwozero3"

이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.

 

 

 

 

내 생각

숫자에 대응되는 영단어가 있다.

 

1. Hash 이용 

key-value를 사용하는 Hash 이용 

2. enumerate 이용

iterable한 자료형을 넣으면 (인덱스, 값) 형태로 enumerate 객체를 반환한다.

 

단어를 숫자로 바꿔야한다 : replace() 사용

 

어려운 문제는 아니었으나, Hash나 enumerate 등 딕셔너리 사용법을 몰랐으면 많이 어려웠을것이다! 

사용법을 잘 익혀두자!

 

 

 

 

코드

1.

def solution(s):
    dic = {'zero':'0', 'one':'1', 'two':'2', 'three':'3', 'four':'4', 'five':'5', 'six':'6', 'seven':'7', 'eight':'8', 'nine':'9'}
    for key in dic:
        s = s.replace(key, dic[key])
    return int(s)

 

2.

def solution(s):
    en = ['zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine']
    for idx, word in enumerate(en):
        if word in s:
            s = s.replace(word, str(idx))
    return int(s)
728x90
반응형