Slump 조건
1. D or E로 시작
2. 첫 글자 이후엔 F가 1개 이상은 반드시 옴.
3. F이후에 Slump또는 G가 와야함
Slimp 조건
1. A로 시작.
2. 총 두글자라면 반드시 AH여야함.
3. 길이가 2 이상이면 두 가지 경우가 있음.
-> AB(Slimp)C
-> A(Slump)C
Slurpy 조건
Slimp에 이어서 Slump가 나오는 문자열
조건에따라 주어진 문자열이 Slurpy가 맞는지 확인하는 문제입니다.
isSlump()와 isSlimp() 함수를 재귀적으로 작동하게 만들어서 풀었습니다.
먼저 처음으로 주어진 문자열에서 D 또는 E의 바로 이전에 C가 있는 경우를 찾아서 전체 문자열을 Slimp와 Slump로 나눴습니다.
Slump의 경우 F가 등장한 경우 계속해서 진행하며, G가 등장하면 리턴,
D 또는 E가 등장하면 새로운 Slump가 시작된다는 의미이므로 다시 Slump를 호출하는 식으로 처리했습니다.
Slimp의 경우 문자열의 길이가 2인경우, AH가 맞다면 true, 아니라면 false를 리턴해주었고,
2 이상의 길이인 경우 조건에 맞게 재귀적으로 호출하면서 풀었습니다
소스코드.
더보기
#include<iostream>
using namespace std;
#pragma warning(disable:4996);
bool isSlump(string str) {
int size = str.length();
if (str[0] != 'D' && str[0] != 'E' || str[size - 1] != 'G') return false;
for (int i = 1; i < size; i++) {
if (str[i] == 'D' || str[i] == 'E') {
if (str[i - 1] != 'F') return false;
string sub_slump = str.substr(i, size);
if (isSlump(sub_slump)) {
return true;
}
else {
return false;
}
}
else if (str[i] != 'F' && str[i] != 'G') return false;
else if (str[i] == 'G') {
if (i != size - 1 || str[i - 1] != 'F')
return false;
}
}
return true;
}
bool isSlimp(string str) {
int size = str.length();
if (str[0] != 'A' || size == 1) return false;
if (size == 2) {
if (str == "AH") return true;
else return false;
}
if (str[1] == 'B') {
string sub_slimp = str.substr(2, size - 3);
if (isSlimp(sub_slimp) && str[size - 1] == 'C') {
return true;
}
}
else if (str[1] == 'D' || str[1] == 'E') {
string sub_slump = str.substr(1, size - 2);
if (isSlump(sub_slump) && str[size - 1] == 'C') {
return true;
}
}
return false;
}
int main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int TestCase;
cin >> TestCase;
cout << "SLURPYS OUTPUT\n";
while (TestCase--) {
string str;
cin >> str;
string slimp, slump;
for (int i = 0; i < str.length(); i++) {
if (str[i] == 'D' || str[i] == 'E') {
if (i == 0) break;
if (str[i - 1] == 'C' || str[i - 1] == 'H') {
slimp = str.substr(0, i);
slump = str.substr(i, str.length());
break;
}
}
}
if (slump.empty() || slimp.empty()) {
cout << "NO\n";
}
else if (isSlimp(slimp) && isSlump(slump)) {
cout << "YES\n";
}
else {
cout << "NO\n";
}
}
cout << "END OF OUTPUT\n";
return 0;
}