結果

問題 No.380 悪の台本
ユーザー pekempeypekempey
提出日時 2016-06-18 00:03:12
言語 C++11
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 1,936 bytes
コンパイル時間 1,570 ms
コンパイル使用メモリ 163,680 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-04-24 14:26:04
合計ジャッジ時間 2,339 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
5,248 KB
testcase_01 AC 2 ms
5,376 KB
testcase_02 AC 2 ms
5,376 KB
testcase_03 AC 1 ms
5,376 KB
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 AC 128 ms
5,376 KB
testcase_08 AC 4 ms
5,376 KB
testcase_09 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

string to_lower(string s) {
	for (char &c : s) if (isalpha(c)) c = tolower(c);
	return s;
}

bool is_symbol(char x) {
	return !isalpha(x) && !isdigit(x);
}

pair<string, string> split(string s) {
	int i = 0;
	while (i < s.size() && s[i] != ' ') i++;
	if (i == s.size()) return make_pair("", s);
	return make_pair(s.substr(0, i), s.substr(i + 1));
}

bool is_digi(string s) {
	for (int i = 0; i < 4; i++) {
		if (s.size() <= 2) return false;
		if (s.substr(s.size() - 3) == "nyo") return true;
		if (!is_symbol(s.back())) return false;
		s.pop_back();
	}
	return false;
}

bool is_petit(string s) {
	for (int i = 0; i < 4; i++) {
		if (s.size() <= 2) return false;
		if (s.substr(s.size() - 3) == "nyu") return true;
		if (!is_symbol(s.back())) return false;
		s.pop_back();
	}
	return false;
}

bool is_rabi(string s) {
	if (s.empty()) return false;
	for (char c : s) {
		if (!is_symbol(c)) return true;
	}
	return false;
}

bool is_gema(string s) {
	for (int i = 0; i < 4; i++) {
		if (s.size() <= 3) return false;
		if (s.substr(s.size() - 4) == "gema") return true;
		if (!is_symbol(s.back())) return false;
		s.pop_back();
	}
	return false;
}

bool is_piyo(string s) {
	for (int i = 0; i < 4; i++) {
		if (s.size() <= 2) return false;
		if (s.substr(s.size() - 3) == "pyo") return true;
		if (!is_symbol(s.back())) return false;
		s.pop_back();
	}
	return false;
}

bool solve(string s) {
	auto v = split(s);
	string t = to_lower(v.second);

	while (t.back() == '\n') t.pop_back();

	if (v.first == "digi") {
		return is_digi(t);
	} else if (v.first == "petit") {
		return is_petit(t);
	} else if (v.first == "rabi") {
		return is_rabi(t);
	} else if (v.first == "gema") {
		return is_gema(t);
	} else if (v.first == "piyo") {
		return is_piyo(s);
	} else {
		return false;
	}
} 

int main() {
	string s;
	while (getline(cin, s)) {
		puts(solve(s) ? "CORRECT (maybe)" : "WRONG!");
	}
}
0