문제 설명
네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
- 1478 → "one4seveneight"
- 234567 → "23four5six7"
- 10203 → "1zerotwozero3"
이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열
s
가 매개변수로 주어집니다.s
가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.참고로 각 숫자에 대응되는 영단어는 다음 표와 같습니다.
숫자 영단어 0 zero 1 one 2 two 3 three 4 four 5 five 6 six 7 seven 8 eight 9 nine
제한사항
- 1 ≤
s
의 길이 ≤ 50
s
가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.
- return 값이 1 이상 2,000,000,000 이하의 정수가 되는 올바른 입력만
s
로 주어집니다.
- 1 ≤
입출력 예
s result "one4seveneight"
1478 "23four5six7"
234567 "2three45sixseven"
234567 "123"
123
풀이
def solution(s):
alpha = ['zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine'] # 알파벳을 모두 입력한 리스트 생성
for num, alp in enumerate(alpha): # enumerate 함수를 사용해 num이 0일때,alp가 'zero'가 되도록 for문
if alp in s: #문자열 안에 알파벳이 있다면
s = s.replace(alp,str(num)) #문자열의 해당 알파벳을 숫자로 치환
return int(s) # s는 string이니까 integer로 형변환
- 점수는 +2
'코딩테스트 > 프로그래머스(Python)' 카테고리의 다른 글
[프로그래머스] Lv1. 2016년 (0) | 2023.01.29 |
---|---|
[프로그래머스] Lv1.두 개 뽑아서 더하기 (0) | 2023.01.29 |
[프로그래머스] Lv1. K번째수 (0) | 2023.01.29 |
[프로그래머스] Lv1. 숫자 문자열과 영단어 (0) | 2023.01.29 |
[프로그래머스] Lv1. K번째수 (0) | 2023.01.29 |
Uploaded by Notion2Tistory v1.1.0