统计元音
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()读取一次即可,而不能放到循环内,否则第二个字符串乃至最后一个字符串的第一个字母都会被读取走,从而导致错误的结果。
查看14道真题和解析