네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.
다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
1478 → "one4seveneight"
234567 → "23four5six7"
10203 → "1zerotwozero3"
이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.
분명 내 코드보다 훨씬 깨끗한 방법이 있을테지만 한참 삽질하다가 푼거라서 기록으로 남김😭
예외가 될 법한 경우를 생각하는게 어렵다..
혹시 이 글을 보는 분이 있다면 "1zero0one", "100"와 같은 케이스를 고려해야 통과 가능합니다!
function solution(s) {
const strToNum = {
"zero": 0,
"one": 1,
"two": 2,
"three": 3,
"four": 4,
"five": 5,
"six": 6,
"seven": 7,
"eight": 8,
"nine": 9
}
let answer = ""
let temp = ""
if(Number(s)) return Number(s)
for(let i = 0; i < s.length; i++) {
if(Number(s[i])) {
answer += s[i]
} else {
temp += s[i]
}
if(strToNum[temp] !== undefined) {
if(strToNum[temp] == 0) {
answer += "0"
} else {
temp = strToNum[temp].toString()
answer += temp
}
temp = ""
}
}
return Number(answer)
}
✔문제출처:프로그래머스