문제 설명
네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다. 다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
1478 → "one4seveneight"
234567 → "23four5six7"
10203 → "1zerotwozero3"
이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.제한사항
1 ≤ s의 길이 ≤ 50
s가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.
return 값이 1 이상 2,000,000,000 이하의 정수가 되는 올바른 입력만 s로 주어집니다.
입출력 예
s: "one4seveneight" → return: 1478
s: "23four5six7" → return 234567
function solution(s) {
let num = [ "zero","one","two","three","four","five","six","seven","eight","nine",];
let tmp = "";
let answer = "";
for (let i = 0; i < s.length; i++) {
if (isNaN(s[i])) { //숫자가 아니면 (문자이면)
tmp += s[i]; //한 글자씩 모아서
let idx = num.indexOf(tmp); // 어떤 숫자인가? => num 배열의 인덱스 값
if (idx > -1) { //찾았다!!
answer += idx;
tmp = "";
}
} else answer += s[i]; //숫자면 바로 정답 배열로
}
return +answer; // 문자열 형태의 정답을 숫자 형태로 만듦
}