본문 바로가기
개발 노트/백준, 프로그래머스 풀이

[백준 1181/c++] 단어 정렬

by tokkiC 2022. 7. 1.

중복을 허락하지 않고 커스텀 조건으로 정렬 - 아하 set을 쓰면 되겠군!

set을 사용한 커스텀 정렬은 처음 써보았다 set의 템플릿에 맞게 struct 의 내부를 원하는 조건으로 커스텀해준뒤

입력을 받아 set에 넣으면 원하는 조건으로 정렬이 된다. 그대로 출력하면 완성이다!

https://www.acmicpc.net/problem/1181

 

1181번: 단어 정렬

첫째 줄에 단어의 개수 N이 주어진다. (1 ≤ N ≤ 20,000) 둘째 줄부터 N개의 줄에 걸쳐 알파벳 소문자로 이루어진 단어가 한 줄에 하나씩 주어진다. 주어지는 문자열의 길이는 50을 넘지 않는다.

www.acmicpc.net

#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;
}

댓글