[프로그래머스] 문자열 정렬하기 (1)
카테고리 : 컴퓨터 공학
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 문자열 정렬하기 (1) · js 문자열 정렬하기 (1)
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 문자열 정렬하기 (1) · js 문자열 정렬하기 (1)
문제 설명
문자열 my_string
이 매개변수로 주어질 때, my_string
안에 있는 숫자만 골라 오름차순 정렬한 리스트를 return 하도록 solution 함수를 작성해보세요.
제한사항
- 1 ≤
my_string
의 길이 ≤ 100 my_string
에는 숫자가 한 개 이상 포함되어 있습니다.my_string
은 영어 소문자 또는 0부터 9까지의 숫자로 이루어져 있습니다. - - -
입출력 예
my_string | result |
---|---|
“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));
}
//정규식을 활용해서 숫자인것만 판별해서 정렬해주는 방법