统计元音
Problem Description
统计每个元音字母在字符串中出现的次数。
Input
输入数据首先包括一个整数n,表示测试实例的个数,然后是n行长度不超过100的字符串。
Output
对于每个测试实例输出5行,格式如下:
a:num1
e:num2
i:num3
o:num4
u:num5
多个测试实例之间由一个空行隔开。
请特别注意:最后一块输出后面没有空行:)
Sample Input
2
aeiou
my name is ignatius
Sample Output
a:1
e:1
i:1
o:1
u:1
a:2
e:1
i:3
o:0
u:1
代码如下:
#include<stdio.h>
#include<string.h>
int main()
{
int n,i;
scanf("%d",&n);
char temp;
temp=getchar();
for(i=0;i<n;i++)
{
int j,k,c[5]={
0,0,0,0,0};
char a[200],b[5]={
'a','e','i','o','u'};
gets(a);
int len=strlen(a);
for(j=0;j<len;j++)
{
for(k=0;k<5;k++)
if(a[j]==b[k]) c[k]++;
}
for(k=0;k<5;k++)
printf("%c:%d\n",b[k],c[k]);
if(i!=n-1) printf("\n");
}
}
总结:
这一题的关键就在于第一个字符串读取前有一个换行符,需要在这些输入的测试用例前读取走,否则会被当一个字符串,从而输出
a:0
e:0
i:0
o:0
u:0
又因为只有第一个字符串前输入的有换行符,所以只需要在循环前用getchar()读取一次即可,而不能放到循环内,否则第二个字符串乃至最后一个字符串的第一个字母都会被读取走,从而导致错误的结果。