문자열 my_string
이 매개변수로 주어질 때, my_string
안에 있는 숫자만 골라 오름차순 정렬한 리스트를 return 하도록 solution 함수를 작성해보세요.
my_string
의 길이 ≤ 100my_string
에는 숫자가 한 개 이상 포함되어 있습니다.my_string
은 영어 소문자 또는 0부터 9까지의 숫자로 이루어져 있습니다. - - -my_string | result |
---|---|
"hi12392" | [1, 2, 2, 3, 9] |
"p2o4i8gj2" | [2, 2, 4, 8] |
"abcde0" | [0] |
입출력 예 #1
입출력 예 #2
입출력 예 #3
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를 사용하여 오름차순으로 정렬해준다.
*/
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로 오름차순으로 정렬을 해준다,
*/
const solution = (my_string) =>
Array.from(my_string).filter(x=> !isNaN(+x)).sort((a, b) => a - b).map(x => +x);
/* 다른 분의 코드를 보다가 Number나 parseInt 없이 매개변수 앞에 +를 작성해주어 문자 => 숫자로
강제 형 변환을 해주는 방법이 신기해서 작성해 보았다. */