[프로그래머스/C++] ㅡ LV1 - 문자열 내 마음대로 정렬하기

2021. 3. 14. 16:39필요/코딩테스트(프로그래머스)

문제

programmers.co.kr/learn/courses/30/lessons/12915

 

코딩테스트 연습 - 문자열 내 마음대로 정렬하기

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

programmers.co.kr

풀이

#include <string>
#include <vector>
#include <algorithm>

using namespace std;

int N;
bool cmp (string a, string b) {
        if (a[N] < b[N]) return true;
        else if (a[N] > b[N]) return false; // n번째 문자열 비교
        
        if (a < b) return true;	// 전체 문자열 비교
        else return false;
}

vector<string> solution(vector<string> strings, int n) {
    N = n;
    sort(strings.begin(), strings.end(), cmp);
    return strings;
}

풀이

cmp 내부에서 if문 두개를 사용했다.

비교할 n번째 문자열이 같다면 1번째 if문은 그냥 통과하게 된다.

그 경우 문자열을 사전순으로 정렬시키면 된다.

 

cmp내부에 n을 넣는 방식이 어려웠었는데, 생각보다 단순한 방식으로 해결이 된다.

cmp 함수 정의 이전에 정의한 변수에 값을 대입시키면 된다.