HDU OJ Problem 2027
Problem Description 统计每个元音字母在字符串中出现的次数。
Input 输入数据首先包括一个整数n,表示测试实例的个数,然后是n行长度不超过100的字符串。
Output 对于每个测试实例输出5行,格式如下:
a:num1
e:num2
i:num3
o:num4
u:num5
多个测试实例之间由一个空行隔开。
请特别注意:最后一块输出后面没有空行:)
Sample Input2
aeiou
my name is ignatius
Sample Outputa:1
e:1
i:1
o:1
u:1
a:2
e:1
i:3
o:0
u:1
去除getchar()
#include<stdio.h>
#include<string.h>
int main()
{
int n,i,len,q,w,e,r,t;
char a[100];
scanf("%d",&n);
//getchar();
while(n–)
{
gets(a);
q=0;w=0;e=0;r=0;t=0;
len=strlen(a);
for(i=0;i<len;i++)
{
if(a[i]‘a’)
q++;
if(a[i]‘e’)
w++;
if(a[i]‘i’)
e++;
if(a[i]‘o’)
r++;
if(a[i]==‘u’)
t++;
}
printf(“a:%d\ne:%d\ni:%d\no:%d\nu:%d\n”,q,w,e,r,t);
if(n>0)
printf("\n");
}
return 0;
}
getchar()和gets(a)一起用
问题出在输入完 2 后的回车键,对于系统来说回车也是一种字符,相当于第一个字符串是一个回车键,所以输入完 2 回车会弹出结果
如果在输入完 2 后调入getchar函数相当于解决掉了回车。