문제 설명

문자열 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 합니다.

✍ SOLUTION1

const solution = (my_string) => 
my_string.split("")
.filter(x=>!isNaN(x))
.map(x=>parseInt(x))
.sort((a, b) => a-b);

/* 
내가 처음 작성한 코드이다. 
1. split을 사용하여 입력받은 my_string을 배열로 변환해준다.
2. filter를 사용하여 my_string의 요소를 순회하며 !isNaN으로 숫자인것을 추출해준다.
3. map으로 해당 string을 parseInt로 숫자로 형변환을 해준다.
4. sort를 사용하여 오름차순으로 정렬해준다.
*/

✍ SOLUTION2

const solution = (my_string) => 
my_string.match(/[0-9]/g).map(x => Number(x)).sort((a, b)=> a - b);

/* 
다른분이 작성한 코드인데 match 메서드와 정규표현식으로 풀이를 할 수 있는 방법이 신기해서 작성해보았다.
1. my_string.match(/[0-9]/g)
match 메서드를 사용하여 정규 표현식으로 my_string에 0-9까지의 숫자가 있는지 확인해준다.
2. map(x=> Number(x))
map을 사용하여 해당 요소들을 Number로 강제 형변환을 해준다.
3. sort((a, b)=> a - b);
sort로 오름차순으로 정렬을 해준다,
 */

String.prototype.match

✍ SOLUTION3

const solution = (my_string) => 
Array.from(my_string).filter(x=> !isNaN(+x)).sort((a, b) => a - b).map(x => +x);

/* 다른 분의 코드를 보다가 Number나 parseInt 없이 매개변수 앞에 +를 작성해주어 문자 => 숫자로
강제 형 변환을 해주는 방법이 신기해서 작성해 보았다. */

출처 : 프로그래머스 스쿨 | 코딩테스트 연습

0개의 댓글