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
반응형