728x90
반응형
소스코드
#include<iostream> #include<algorithm> #include<vector> using namespace std; int N; bool cmp(string a, string b) { if (a.size() == b.size())return a < b; return a.size() < b.size(); } vector<string> name; void initData() { scanf("%d", &N); name.clear(); for (int n = 0; n < N; n++) { string lifeName; cin >> lifeName; name.push_back(lifeName); } sort(name.begin(), name.end(), cmp); } int main(int argc, char** argv) { int test_case; int T; cin >> T; for (test_case = 1; test_case <= T; ++test_case) { initData(); printf("#%d\n", test_case); for (int n = 0; n < N; n++) { if (name[n] == name[n + 1]) { continue; } cout << name[n] << '\n'; } } return 0;//정상종료시 반드시 0을 리턴해야합니다. }
설계
- 사실 정렬 문제는 라이브러리가 잘되어 있어서 쓰면되는데
- 여기서 포인트는 중복인 것 출력 안되게 해주면됨
실수
- 사이즈가 작은것이라는 우선 순위 정렬이 있었음
- 이것을 빼먹은 것 빼고는 사실 38.45%가 이해가 되지 않음
문제 링크
원본
728x90
반응형
'알고리즘 모음집 > New 알고리즘' 카테고리의 다른 글
2021.11.11_7728-다양성측정 (0) | 2021.11.11 |
---|---|
2021.11.10_7829-보물왕태혁 (0) | 2021.11.10 |
2021.11.08_1218-괄호짝짓기 (0) | 2021.11.08 |
2021.11.07_8673-코딩토너먼트1 (0) | 2021.11.08 |
2021.11.06_1217-거듭제곱 (0) | 2021.11.08 |
댓글