중복을 허락하지 않고 커스텀 조건으로 정렬 - 아하 set을 쓰면 되겠군!
set을 사용한 커스텀 정렬은 처음 써보았다 set의 템플릿에 맞게 struct 의 내부를 원하는 조건으로 커스텀해준뒤
입력을 받아 set에 넣으면 원하는 조건으로 정렬이 된다. 그대로 출력하면 완성이다!
https://www.acmicpc.net/problem/1181
#include <bits/stdc++.h>
using namespace std;
struct tok
{
bool operator() (const string& left, const string& right) const
{
if(left.size() == right.size()) {
return left < right;
} else {
return left.size() < right.size();
}
}
};
int main(){
int n;
string s;
cin >> n;
set<string, tok> st;
for(int i=0; i<n; i++){
cin >> s;
st.insert(s);
}
for(auto k : st){
cout << k << "\n";
}
return 0;
}
'개발 노트 > 백준, 프로그래머스 풀이' 카테고리의 다른 글
[백준 11729/c++] 하노이의 탑 이동 순서 (0) | 2022.07.03 |
---|---|
[백준 12871/c++] 무한 문자열 (0) | 2022.07.02 |
[백준 10610/c++] 30 (0) | 2022.07.01 |
[백준 2477/c++] 참외밭 (0) | 2022.07.01 |
[백준 2839/c++] 설탕 배달 (0) | 2022.06.30 |
댓글