문제
https://www.acmicpc.net/problem/11656
해결방법
1. 입력 받은 문자열을 substr 함수를 이용하여 각각의 접미사를 따로 배열에 저장한다. substr은 (시작지점, 길이)를 전달받아 부분 문자열을 리턴하므로 시작지점을 0~문자열 길이-1까지 넣어주면 된다.
2. sort를 사용하여 정렬 후 출력한다.
코드
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
string str;
cin >> str;
string arr[1001];
for (int i = 0; i < str.length(); i++) {
arr[i] = str.substr(i, str.length());
}
sort(arr, arr + str.length());
for (int i = 0; i < str.length(); i++) {
cout << arr[i] << '\n';
}
return 0;
}
'PS > 백준' 카테고리의 다른 글
[C++] 백준 24072: 帰省 (Homecoming) (0) | 2023.05.05 |
---|---|
[C++] 백준 21354: Äpplen och päron (1) | 2023.05.04 |
[C++] 백 11721: 열 개씩 끊어 출력하기 (0) | 2023.04.26 |
[C++] 백준 2776: 암기왕 (0) | 2023.04.13 |
[C++] 백준 19592: 장난감 경주 (0) | 2023.04.12 |
댓글