Codeforces Beta Round #70 (Div. 2) / 78A Haiku (字符串处理)

A. Haiku
http://codeforces.com/problemset/problem/78/A
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

Haiku is a genre of Japanese traditional poetry.

A haiku poem consists of 17 syllables split into three phrases, containing 5, 7 and 5 syllables correspondingly (the first phrase should contain exactly 5 syllables, the second phrase should contain exactly 7 syllables, and the third phrase should contain exactly 5 syllables). A haiku masterpiece contains a description of a moment in those three phrases. Every word is important in a small poem, which is why haiku are rich with symbols. Each word has a special meaning, a special role. The main principle of haiku is to say much using a few words.

To simplify the matter, in the given problem we will consider that the number of syllable in the phrase is equal to the number of vowel letters there. Only the following letters are regarded as vowel letters: "a", "e", "i", "o" and "u".

Three phases from a certain poem are given. Determine whether it is haiku or not.

Input

The input data consists of three lines. The length of each line is between 1 and 100, inclusive. The i-th line contains the i-th phrase of the poem. Each phrase consists of one or more words, which are separated by one or more spaces. A word is a non-empty sequence of lowercase Latin letters. Leading and/or trailing spaces in phrases are allowed. Every phrase has at least one non-space character. See the example for clarification.

Output

Print "YES" (without the quotes) if the poem is a haiku. Otherwise, print "NO" (also without the quotes).

Sample test(s)
input
on  codeforces 
beta round is running
   a rustling of keys 
output
YES
input
how many gallons
of edo s rain did you drink
                                cuckoo
output
NO

water.


/*30ms,0KB*/

#include<cstdio>
#include<cstring>
#define init(a) memset(a,0,sizeof(a))

char str[101];

int main(void)
{
	int count[3] = {0, 0, 0};
	for (int i = 0; i < 3; ++i)
	{
		init(str);
		gets(str);
		int len = strlen(str);
		for (int j = 0; j < len; ++j)
			if (str[j] == 'a' || str[j] == 'e' || str[j] == 'i' || str[j] == 'o' || str[j] == 'u')
				++count[i];
	}
	printf(count[0] == 5 && count[1] == 7 && count[2] == 5 ? "YES" : "NO");
	return 0;
}



你可能感兴趣的:(ACM,codeforces)