문제 설명
네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.
다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
- 1478 → "one4seveneight"
- 234567 → "23four5six7"
- 10203 → "1zerotwozero3"
이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.
참고로 각 숫자에 대응되는 영단어는 다음 표와 같습니다.
제한사항
- 1 ≤ s의 길이 ≤ 50
- s가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.
- return 값이 1 이상 2,000,000,000 이하의 정수가 되는 올바른 입력만 s로 주어집니다.
입출력 예
입출력 예 설명
입출력 예 #1
- 문제 예시와 같습니다.
입출력 예 #2
- 문제 예시와 같습니다.
입출력 예 #3
- "three"는 3, "six"는 6, "seven"은 7에 대응되기 때문에 정답은 입출력 예 #2와 같은 234567이 됩니다.
- 입출력 예 #2와 #3과 같이 같은 정답을 가리키는 문자열이 여러 가지가 나올 수 있습니다.
입출력 예 #4
- s에는 영단어로 바뀐 부분이 없습니다.
코드
def solution(s):
answer = 0
dic = { 'zero': '0', 'one': '1', 'two': '2', 'three': '3', 'four': '4',
'five': '5', 'six': '6', 'seven': '7', 'eight': '8', 'nine': '9' }
for dic_key, dic_val in zip(dic, dic.values()):
if s.isdigit():
break
s = s.replace(dic_key, dic_val)
answer = int(s)
return answer
풀이
딕셔너리를 선언해서 그곳에 영단어과 그에 따른 숫자들을 넣어준다. zip으로 두 개를 묶어 반복문을 실행한다. 반복문이 실행되면 s가 숫자일 경우 변환만 하면 되어 굳이 for문을 다 돌 필요가 없기 때문에 s가 숫자인지 확인해주고 break를 해준다. s에 영단어도 포함되어있을 경우에는 replace()를 이용해 s에 영단어를 숫자로 대체한다. 그리고나서 for문이 끝나면 s를 문자열에서 정수형으로 변환해준다.
다른 코드와 풀이
아래의 코드는 다른 사람들이 작성한 것들로, 내 코드와 비교, 참고하기 위해 가져왔다.
1️⃣
num_dic = {"zero":"0", "one":"1", "two":"2", "three":"3", "four":"4", "five":"5", "six":"6", "seven":"7", "eight":"8", "nine":"9"}
def solution(s):
answer = s
for key, value in num_dic.items():
answer = answer.replace(key, value)
return int(answer)
asnwer에 s를 할당해주고, num_div의 key, value값을 가져와 반복문을 돌린다. 반복문 안에서 answer에 있는 key값을 value로 대체 후 반복문이 종료되면 그 값을 정수형으로 변환한다.
2️⃣
def solution(s):
words = ['zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine']
for i in range(len(words)):
s = s.replace(words[i], str(i))
return int(s)
리스트를 선언하여 영어 단어를 리스트에 넣어준다. 그리고 리스트의 길이만큼 반복문을 돌려 문자열 s에 words의 i번째에 오는 단어를 문자열로 변환한 i로 대체해준 후 반복문이 종료되면 그 값을 정수형으로 변환한다.
'Coding Test' 카테고리의 다른 글
231104 K번째수 - Level 1 (0) | 2023.11.04 |
---|---|
231103 가장 가까운 같은 글자 - Level 1 (0) | 2023.11.03 |
231101 시저암호 - Level 1 (1) | 2023.11.01 |
231031 크기가 작은 부분 문자열 - Level 1 (0) | 2023.10.31 |
231030 이상한 문자 만들기 - Level 1 (1) | 2023.10.30 |