[프로그래머스] 문자열 정렬하기 (1)


문제 설명

문자열 my_string이 매개변수로 주어질 때, my_string안에 있는 숫자만 골라 오름차순 정렬한 리스트를 return 하도록 solution 함수를 작성해보세요.


제한사항

  • 1 ≤ my_string의 길이 ≤ 100
  • my_string에는 숫자가 한 개 이상 포함되어 있습니다.
  • my_string은 영어 소문자 또는 0부터 9까지의 숫자로 이루어져 있습니다. - - -

입출력 예

my_stringresult
“hi12392”[1, 2, 2, 3, 9]
“p2o4i8gj2”[2, 2, 4, 8]
“abcde0”[0]

입출력 예 설명

입출력 예 #1

  • “hi12392”에 있는 숫자 1, 2, 3, 9, 2를 오름차순 정렬한 [1, 2, 2, 3, 9]를 return 합니다.

입출력 예 #2

  • “p2o4i8gj2”에 있는 숫자 2, 4, 8, 2를 오름차순 정렬한 [2, 2, 4, 8]을 return 합니다.

입출력 예 #3

  • “abcde0”에 있는 숫자 0을 오름차순 정렬한 [0]을 return 합니다.

나의 풀이

function solution(my_string) {
  var answer = [...my_string]
    .filter((a) => !Number.isNaN(+a))
    .map((a) => +a)
    .sort((a, b) => a - b);
  return answer;
}

나의 두번째 풀이(Code Refactoring)

function solution(my_string) {
  let result = [];
  for (i = 0; i < my_string.length; i++) {
    let toNumber = parseInt(my_string[i]);
    if (!isNaN(toNumber)) {
      result.push(Number(my_string[i]));
    }
  }
  return result.sort();
}

// my_string를 순회해서 숫자로 변환
// 숫자인것만 판별해서 result에 담고 , Number로 타입을 변환해준다
// result에 a-b 정렬

참고 할 만한 다른 사람의 코드

function solution(my_string) {
  return my_string
    .match(/\d/g)
    .sort((a, b) => a - b)
    .map((n) => Number(n));
}

//정규식을 활용해서 숫자인것만 판별해서 정렬해주는 방법