필요/코딩테스트(프로그래머스)
[프로그래머스/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 함수 정의 이전에 정의한 변수에 값을 대입시키면 된다.