문제 링크
https://www.acmicpc.net/problem/21966
문제
드높은 남산 위에 우뚝 선
(중략)
세워라 반석 위에
선린의 터를
1개 이상의 문장들이 주어진다. 아래 규칙에 따라 문장들의 중간 부분을 적당히 생략해 25글자 이내로 요약해서 출력하는 프로그램을 작성하자.
단, 입출력의 편의를 위해 문장들을 공백 없이 모두 붙여 구성한 문자열 S가 대신 주어진다. 문자열의 첫 글자부터 가장 먼저 만나는 '.'(마침표)까지, 그리고 각 '.'의 다음 글자부터 가장 먼저 만나는 '.'까지를 한 문장으로 생각하기로 하자. 예를 들어 주어진 문자열 S가 'IamInevitable.IamIronMan.'이라면 'IamInevitable.'이 한 문장, 'IamIronMan.'이 한 문장이다.
규칙은 다음과 같다.
- S의 길이가 25 이하면 S를 그대로 출력한다.
- S의 길이가 25 초과이면, S의 앞에서부터 11글자, 뒤에서부터 11글자를 제외하고 나머지 부분을 생각하자. 이 나머지 부분이 모두 같은 문장에 속한다면, 생략한 뒤 '...'('.' 3개)으로 바꿔서 출력한다.
- 위 두 경우에 해당되지 않는다면 S를 앞에서부터 9글자, 뒤에서부터 10글자만 남기고 중간은 '......'('.' 6개)으로 바꿔서 출력한다.
입력
첫 번째 줄에 문자열의 길이 N이 주어진다.
두 번째 줄에는 N글자로 이루어진 문자열 S가 주어진다.
출력
문제에서 제시된 규칙에 따라 S를 25글자 이내로 요약해서 출력한다.
제한
2≤N≤100000
문자열 S는 알파벳 대문자, 알파벳 소문자, 쉼표(,), 마침표(.)로만 구성되어 있다.
문자열 S의 첫 글자는 마침표(.)가 아니다.
문자열 S의 마지막 글자는 마침표(.)이다.
예제 입력 1
11
IamIronMan.
예제 출력 1
IamIronMan.
11글자이므로 그대로 출력하면 된다.
예제 입력 2
26
And,IamIronMan.IamIronMan.
예제 출력 2
And,IamIron...IamIronMan.
'And,IamIronMan.IamIronMan.' 의 길이는 26이므로 그대로 출력할 수 없다.
'And,IamIronMan.IamIronMan.' 에서 앞/뒤 11글자를 제외한 나머지 부분은 'Man.' 으로, 한 문장 안에 포함되었기 때문에 '...'으로 치환할 수 았다.
그러므로 'And,IamIron...IamIronMan.' 이 정답이 된다.
예제 입력 3
29
IamInevitable.And,IamIronMan.
예제 출력 3
IamInevit......amIronMan.
'IamInevitable.And,IamIronMan.' 의 길이는 29이므로 그대로 출력할 수 없다.
'IamInevitable.And,IamIronMan.' 에서 앞/뒤 11글자를 제외한 나머지 부분은 'le.And,' 으로, 한 문장 안에 포함되지 않았기 때문에 '...'으로 치환할 수 없다.
그러므로 앞 9글자, 뒤 10글자를 제외한 나머지 부분을 '......'으로 치환한 'IamInevit......amIronMan.'이 정답이 된다.
힌트
알파벳 대문자, 알파벳 소문자, 쉼표, 마침표의 아스키 코드는 각각 65-90, 97-122, 44, 46이다.
알고리즘 분류
- 문자열
- 많은 조건 분기
풀이
N이 25 이하면 그냥 S를 그대로 출력한다.
N이 25 이상이면 문자열 S의 11번째 문자부터 N-13번째 문자까지 중간에 .가 한 번이라도 나오면 한 문장 안에 포함되지 않은 것이므로, 앞에서부터 9번째 문자와 뒤에서부터 10번째 문자 사이의 문자열을 ......로 치환한다. 중간에 .가 한 번이라도 나오지 않았다면 한 문장 안에 포함된 것이므로, 앞에서부터 11번째 문자와 뒤에서부터 11번째 문자 사이의 문자열을 ...로 치환한다.
코드
#include <iostream>
#include <string>
#include <cmath>
#include <unordered_set>
#include <unordered_map>
#include <bitset>
#include <ctime>
#include <stack>
#include <queue>
#include <vector>
#include <algorithm>
#include <climits>
#define FASTIO cin.tie(NULL); cout.tie(NULL); ios::sync_with_stdio(false);
#define MAX 11
#define LL long long
#define INF 1e9
using namespace std;
int N;
string S;
string Answer = "";
void Input() {
cin >> N;
cin >> S;
}
void Settings() {
if (N <= 25) {
Answer = S;
}
else {
bool Flag = true;
for (int i = 11; i < (N - 12); i++) {
if (S[i] == '.') {
Flag = false;
break;
}
}
if (Flag) {
Answer += S.substr(0, 11);
Answer += "...";
Answer += S.substr(N - 11);
}
else {
Answer += S.substr(0, 9);
Answer += "......";
Answer += S.substr(N - 10);
}
}
}
void Find_Answer() {
cout << Answer << "\n";
}
int main() {
FASTIO
Input();
Settings();
Find_Answer();
return 0;
}
'BOJ > Silver' 카테고리의 다른 글
[BOJ/Silver 1] 백준 2730 오늘은 OS 숙제 제출일(C++) (0) | 2022.05.27 |
---|---|
[BOJ/Silver 3] 백준 11332 시간초과(C++) (0) | 2022.05.26 |
[BOJ/Silver 3] 백준 1614 영식이의 손가락(C++) (0) | 2022.05.26 |
[BOJ/Silver 3] 백준 17479 정식당(C++) (0) | 2022.05.16 |
[BOJ/Silver 3] 백준 17264 I AM IRONMAN(C++) (0) | 2022.05.09 |