Dragonball Online Goku Hand
본문 바로가기
알고리즘 도장깨기

프로그래머스 Lv.1 "문자열 내 마음대로 정렬하기"

by 별의 코비 2022. 12. 5.
728x90

🔥 Programmers Lv.1 : 문자열 내 마음대로 정렬하기


🔍 문제 : " 문자열로 구성된 리스트 strings와, 정수 n이 주어졌을 때, 각 문자열의 인덱스 n번째 글자를 기준으로 오름차순 정렬하려 합니다. 예를 들어 strings가 ["sun", "bed", "car"]이고 n이 1이면 각 단어의 인덱스 1의 문자 "u", "e", "a"로 strings를 정렬합니다. "

📎 조건 :
∙ strings는 길이 1 이상, 50이하인 배열입니다.
∙ strings의 원소는 소문자 알파벳으로 이루어져 있습니다.
∙ strings의 원소는 길이 1 이상, 100이하인 문자열입니다.
∙ 모든 strings의 원소의 길이는 n보다 큽니다.
∙ 인덱스 1의 문자가 같은 문자열이 여럿 일 경우, 사전순으로 앞선 문자열이 앞쪽에 위치합니다.


👉🏻 My answer

function solution(strings, n) {
    // 인덱스 n번째 글자를 기준으로 오름차순 정렬
    let answer = strings.sort((a, b) => {
       if(a[n] > b[n]) return 1;
        if(a[n] < b[n]) return -1;
         // 인덱스 n번째 글자가 같으면 사전순 정렬
        if(a[n] === b[n]){
            if(a>b) return 1;
            if(a<b) return -1;
            return 0;
        }
    });
    return answer;
}
: 주석을 참고해주세요!


👉🏻 Another ways

function solution(strings, n) {
    // strings 배열
    // n 번째 문자열 비교
    return strings.sort((s1, s2) => s1[n] === s2[n] ? s1.localeCompare(s2) : s1[n].localeCompare(s2[n]));
}
: 내부 인덱스를 가지고 비교하는데, 내부 character가 같으면 전체 string을 비교하고 내부 character가 다르면 내부 character을 비교한다라는 의미라고 합니다.
: 간결한데 어렵네요!ㅜㅜ

댓글