배운것
벡터 중복제거
sort(v.begin(), v.end(), cmp);
a.erase(unique(v.begin(), v.end()), v.end());
정답 코드
using namespace std;
bool cmp(string a, string b)
{
int alen = a.size();
int blen = b.size();
if (alen != blen)return alen < blen;
return a < b;
}
int main(void) {
ios::sync_with_stdio(0);
cin.tie(0);
int n;
string str;
cin >> n;
vector<string> a;
for (int i = 0; i < n; i++)
{
cin >> str;
a.push_back(str);
}
sort(a.begin(), a.end(), cmp);
a.erase(unique(a.begin(), a.end()), a.end());
for (int i = 0; i < a.size(); i++)
cout << a[i] << '\n';
return 0;
}
'Algorithm > C++' 카테고리의 다른 글
[백준 11656] 접미사 배열 (0) | 2022.10.04 |
---|---|
[백준 10814] 나이순 정렬 (0) | 2022.10.04 |
[백준 15663] N과 M(9) (0) | 2022.09.28 |
[백준 15657] N과 M (8) (0) | 2022.09.28 |
[백준 9095] 1,2,3 더하기 (0) | 2022.09.28 |
댓글