Algorithm/OnlineJudge

p384 ( Slurpys )

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;
}