네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다. 다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
- 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
s
의 길이 ≤ 50s
가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.s
로 주어집니다.s | result |
---|---|
"one4seveneight" | 1478 |
"23four5six7" | 234567 |
"2three45sixseven" | 234567 |
"123" | 123 |
function solution (s) {
const engNum = ["zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"];
let answer = s;
engNum.map((v,i) => {
let temp = answer.split(v);
answer = temp.join(i);
})
return +answer;
}
"zero"부터 "nine"까지 담긴 영단어 배열 engNum
을 map()
으로 돌리면서, s를 배열로 만든 answer을 engNum
의 요소별로 split()
작업을 하였다. answer에 해당 영단어가 존재한다면 그 영단어를 기준으로 앞 요소들과 뒤 요소들을 나누는 작업이다.
예를 들어, "one4seveneight"이 입력되었다면 engNum을 map으로 돌리면서 가장 먼저 "zero"로 answer를 split()할 수 있는지 확인하고 그 결과를 temp에 할당한다. answer(s를 배열로 만든 값)엔 "zero"가 없으므로 temp는 여전히 "one4seveneight"이다. 다음으로 "one"은 answer에 존재하므로 answer.split("zero")
를 하면 temp는 [ '', '4seveneight' ]
값으로 할당된다. 이때 i는 "one"의 인덱스이자 영단어의 숫자값이다. temp를 join(1)
을 사용해서 split되었던 요소들을 그 요소의 사이에 1을 넣고 하나의 문자열로 만들어 준 뒤 answer에 할당한다. 그러면 answer는 14seveneight
이 된다.
이러한 작업을 반복하면
//split
[ 'one4seveneight' ]
//join
one4seveneight
//split
[ '', '4seveneight' ]
//join
14seveneight
...
//split
[ '14', 'eight' ]
//join
147eight
//split
[ '147', '' ]
//join
1478
//split
[ '1478' ]
//join
1478
과 같이 영단어가 숫자값으로 바뀌게 된다. 그리고 answer를 마지막으로 리턴할 땐 Number타입으로 변환시켜주었다.
function solution(s) {
while(isNaN(+s)) {
s = s.replace('zero',0)
s = s.replace('one',1)
s = s.replace('two',2)
s = s.replace('three',3)
s = s.replace('four',4)
s = s.replace('five',5)
s = s.replace('six',6)
s = s.replace('seven',7)
s = s.replace('eight',8)
s = s.replace('nine',9)
}
return +s
}
전혀 생각하지 못한 기발한 방법이다. 😯 코드가 길고 반복되는 부분이 존재하지만, 이해하기 가장 쉬운 코드인 것 같다.