문제 설명
문자열로 구성된 리스트 strings와 정수 n이 주어졌을 때, 각 문자열의 인덱스 n번째 글자를 기준으로 오름차순 정렬하려 합니다. 예를 들어 strings가 ["sun", "bed", "car"]이고 n이 1이면 각 단어의 인덱스 1의 문자 "u", "e", "a"로 strings를 정렬합니다.
제한사항
- strings는 길이 1 이상, 50 이하인 배열입니다.
- strings의 원소는 소문자 알파벳으로 이루어져 있습니다.
- strings의 원소는 길이 1 이상, 100 이하인 문자열입니다.
- 모든 strings의 원소의 길이는 n보다 큽니다.
- 인덱스 1의 문자가 같은 문자열이 여럿 일 경우, 사전 순으로 앞선 문자열이 앞쪽에 위치합니다.
설명 더 보기
문제 풀이
function solution(strings, n) {
// 문자열의 n번째 글자를 기준으로 오름차순으로 정렬
strings.sort(function (a, b) {
if (a[n] !== b[n]) {
return a[n].localeCompare(b[n]);
// 단, 문자열의 n번째 글자가 같은 경우에는 전체 문자열을 기준으로 사전 순으로 정렬
} else {
return a.localeCompare(b);
}
})
return strings;
}
'ETC > 코딩테스트 연습' 카테고리의 다른 글
[프로그래머스] 최대공약수와 최소공배수 (JavaScript) (0) | 2021.07.30 |
---|---|
[프로그래머스] 수박수박수박수박수박수? (JavaScript) (0) | 2021.07.30 |
[프로그래머스] 같은 숫자는 싫어 (JavaScript) (0) | 2021.07.23 |
[프로그래머스] 가운데 글자 가져오기 (JavaScript) (0) | 2021.07.22 |
[프로그래머스] 두 개 뽑아서 더하기 (JavaScript) (0) | 2021.07.22 |