[Programmers] 숫자 문자열과 영단어 (2021 카카오 채용연계형 인턴십)
2022. 10. 26. 21:08ㆍ기록/Programmers
- 목차
문제 설명
네오와 프로도가 숫자놀이를 하고 있습니다.
네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.
다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
- 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 |
제한 사항
- 1 ≤ s의 길이 ≤ 50
- s가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.
- return 값이 1 이상 2,000,000,000 이하의 정수가 되는 올바른 입력만 s로 주어집니다.
입출력 예
s | result |
"one4seveneight" | 1478 |
"23four5six7" | 234567 |
"2three45sixseven" | 234567 |
"123" | 123 |
입출력 예 설명
입출력 예 #1
- 문제 예시와 같습니다.
입출력 예 #2
- 문제 예시와 같습니다.
입출력 예 #3
- "three"는 3, "six"는 6, "seven"은 7에 대응되기 때문에 정답은 입출력 예 #2와 같은 234567이 됩니다.
- 입출력 예 #2와 #3과 같이 같은 정답을 가리키는 문자열이 여러 가지가 나올 수 있습니다.
입출력 예 #4
- s에는 영단어로 바뀐 부분이 없습니다.
나의 문제 풀이
function solution(s) {
const arr = ['zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine'];
arr.forEach((item, idx) => {
if (s.includes(item)) {
s = s.split(item).join(idx);
}
});
return Number(s);
}
- 영단어들을 배열의 요소로 넣는다.
- 각 배열 요소들이 의미하는 숫자는 인덱스가 된다.
- 배열의 요소들을 하나씩 꺼낸다.
- 주어진 문자열에 현재 인덱스가 가리키는 배열의 요소가 포함되어 있는지 판별한다.
- 포함되어 있는 경우 주어진 문자열을 해당 요소를 구분자로 쪼갠다.
- one4seveneight 에서 one 으로 쪼개면 '', '4seveneight' 으로 나누어진다.
- 두 문자열을 현재 인덱스로 이어서 새로운 문자열을 만들어 주어진 문자열에 할당한다.
- '', '4seveneight' 을 현재 인덱스인 1로 이어주면 '14seveneight' 이 된다.
- 배열 요소의 갯수만큼 위 과정을 반복하면 문자열 s 의 모든 영단어는 숫자로 변경된다.
- 문자열 s 를 숫자 타입으로 변환하여 리턴한다.
다른 사람의 문제 풀이
function solution(s) {
s = s.replace(/zero/gi, 0)
.replace(/one/gi, 1)
.replace(/two/gi, 2)
.replace(/three/gi, 3)
.replace(/four/gi, 4)
.replace(/five/gi, 5)
.replace(/six/gi, 6)
.replace(/seven/gi, 7)
.replace(/eight/gi, 8)
.replace(/nine/gi, 9)
return parseInt(s);
}
- 정규표현식을 사용하여 해당하는 문자들을 숫자로 교체하였다.
function solution(s) {
let charSet = {
"zero" : 0,
"one" : 1,
"two" : 2,
"three" : 3,
"four" : 4,
"five" : 5,
"six" : 6,
"seven" : 7,
"eight" : 8,
"nine" : 9,
}
for(let [key, value] of Object.entries(charSet)) {
let re = new RegExp(`${key}`,"g");
s = s.replace(re, value);
}
return parseInt(s);
}
- 객체의 key : value 속성을 이용해 문자를 숫자로 교체하였다.
const digit2word = ['zero','one','two','three','four','five','six','seven', 'eight','nine']
function solution(s) {
return Number(digit2word.reduce((ans, word, digit) =>
ans.replace(new RegExp(word, 'g'), digit), s)
);
}
- 주어진 문자열을 초기값으로 하여 digit2word 배열 변수를 하나씩 꺼내어 누적한다.
- 누적 변수에서 현재 배열 요소를 찾아 reduce 의 인덱스로 교체한다.