Algorithm - 숫자 문자열과 영단어

박태환·2021년 11월 10일
0

Algorithm

목록 보기
17/20
post-thumbnail

문제 설명


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

다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.

1478 → "one4seveneight"
234567 → "23four5six7"
10203 → "1zerotwozero3"
이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.

참고로 각 숫자에 대응되는 영단어는 다음 표와 같습니다.

숫자영단어
0zero
1one
2two
3three
4four
5five
6six
7seven
8eight
9nine

제한사항

  • 1 ≤ s의 길이 ≤ 50
  • s가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.
  • return 값이 1 이상 2,000,000,000 이하의 정수가 되는 올바른 입력만 s로 주어집니다.

입출력 예

sresult
"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) {
  var answer = "";
  var eng = "";
  const arr = [
    "zero",
    "one",
    "two",
    "three",
    "four",
    "five",
    "six",
    "seven",
    "eight",
    "nine",
  ];
  for (let i = 0; i < s.length; i++) {
    if (isNaN(s[i]) == false) {
      answer += s[i];
    } else {
      eng += s[i];
      for (let j = 0; j < arr.length; j++) {
        if (eng == arr[j]) {
          answer += j;
          eng = "";
        }
      }
    }
  }

  return Number(answer);
}

풀이 설명

먼저 숫자와 영어가 대응하는 배열을 하나 만들었다.
어차피 인덱스와 똑같이 대응하기 때문에 순서대로 영어를 넣어 만들었다.
인자 s의 길이만큼 반복문을 돌려줄건데 만약 숫자가 나오면 바로 answer에 들어간다.
만약 문자열이 나오면 eng에 들어가고 그 문자열이 아까 만들어 두었던 숫자와 영어가 대응하는 배열에 포함이 되어있는지 확인한다.
만약 대응한다면 그 인덱스로 바꿔주고 eng는 비워준다.
그렇게 나온 answer는 숫자가 아닌 문자열이기 때문에 마지막으로 Number를 이용해 숫자로 바꿔주면 정답이 나온다.

다른 사람의 풀이

function solution(s) {
    let numbers = ["zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"];
    var answer = s;

    for(let i=0; i< numbers.length; i++) {
        let arr = answer.split(numbers[i]);
        answer = arr.join(i);
    }

    return Number(answer);
}

다른 사람의 풀이 설명

이건 split과 join의 특성을 아주 잘 이용한 풀이법이다.
예를 들어,
'one4seveneight'의 경우 split을 통해 [ '', '4seveneight'] 이 생성된다.
이후 join(i)를 통하여 두 원소 사이에 '1' (i는 1인 상태기 때문에) 이 들어가게 되어 14seveneight 이 생성된다.
이후 for문을 계속 따라가다보면

[ '14', 'eight'] // split 을 통해 생성.

147eight // join을 통해 생성.

[ '147', ''] // split을 통해 생성.

1478 // join을 통해 생성.

위 과정을 통해 '1478'이라는 문자열이 완성되고 마지막에 Number를 이용해 숫자로 바꿔주면 정답이 완성된다.

느낀 점

확실히 다른 사람의 풀이를 보면 하나의 메서드도 완벽하게 이해하고 있다면 풀이법이 많이 달라지는 것 같다.

profile
mekemeke

0개의 댓글