[프로그래머스] 숫자 문자열과 영단어

·2023년 11월 15일
1

Algorithm

목록 보기
3/16
post-thumbnail

숫자 문자열과 영단어

문제 설명

네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다. 다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.

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

solution code

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;		// 문자열 형태의 정답을 숫자 형태로 만듦
}

0개의 댓글