애플파이썬
[프로그래머스] Lv.1 숫자 문자열과 영단어 (파이썬) 본문
https://school.programmers.co.kr/learn/courses/30/lessons/81301
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
문제 설명

네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.
다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
- 1478 → "one4seveneight"
- 234567 → "23four5six7"
- 10203 → "1zerotwozero3"
이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.
참고로 각 숫자에 대응되는 영단어는 다음 표와 같습니다.
제한사항
- 1 ≤ s의 길이 ≤ 50
- s가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.
- return 값이 1 이상 2,000,000,000 이하의 정수가 되는 올바른 입력만 s로 주어집니다.
틀린 내 코드
def solution(s):
answer =[]
nums = {"zero":"0","one":"1","two":"2","three":"3","four":"4","five":"5","six":'6',"seven":"7","eight":"8","nine":'9'}
number = [x for x in s if x.isdigit()]
for i, x in nums.items():
if i in s:
answer.append(x)
elif x in s:
answer.append(x)
return int(''.join(answer))
흠냐,,, 기억 안 나,, 다시 봐도 이상한 코드구만유,, ㅠㅠ
s 안에 숫자인 것들을 가져와서 number 리스트로 저장하고, 아닌 것들을 바꾸려고 한 것 같은데...
일단 위치(인덱스) 유지 안되는 것이 가장 큰 문제고 불(가능한 ~) 방법 !
다른 사람의 풀이
def solution(s):
nums = {"zero":"0","one":"1","two":"2","three":"3","four":"4","five":"5","six":'6',"seven":"7","eight":"8","nine":'9'}
for i, x in nums.items():
s = s.replace(i, x)
return int(s)
그 당시 나의 인사이트
<@replace@의 존재를 까먹지말기 !!!!!!!!! 바꾸는 문제 나오면 무조건 먼저 한 번 생각하기>
replace와 딕셔너리를 사용하면 이렇게 간단한 문제인 것을,,, 한 번 배운 건 최대한 까먹지 말고 활용해보기!

'파이썬 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] Lv.1 로또의 최고 순위와 최저 순위 (파이썬) (4) | 2025.01.08 |
---|---|
[프로그래머스] Lv.1 카드 뭉치 (파이썬) (4) | 2025.01.07 |
[프로그래머스] Lv.1 가장 가까운 같은 글자 (파이썬) (2) | 2024.12.23 |
[프로그래머스] Lv.1 콜라 문제(파이썬) (2) | 2024.12.23 |
[프로그래머스] Lv.1 삼총사 (파이썬) (3) | 2024.12.04 |