HDU 2027 - 统计元音

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

最后的换行要注意一下!!因为getchar()放错地方了WA了好几次,生无可恋了。

代码:

#include<stdio.h>
#include<string.h>
int main()
{
	char s[110];
	int n,len,flag,i;
	scanf("%d",&n);
	getchar();
	while(n--)
	{
		gets(s);
		len=strlen(s);
		flag=0;
		for(i=0;i<len;i++)
		{
			if(s[i]=='a')
				flag++;
		}
		printf("a:%d\n",flag);
		flag=0;
		for(i=0;i<len;i++)
		{
			if(s[i]=='e')
				flag++;
		}
		printf("e:%d\n",flag);
		flag=0;
		for(i=0;i<len;i++)
		{
			if(s[i]=='i')
				flag++;
		}
		printf("i:%d\n",flag);
		flag=0;
		for(i=0;i<len;i++)
		{
			if(s[i]=='o')
				flag++;
		}
		printf("o:%d\n",flag);
		flag=0;
		for(i=0;i<len;i++)
		{
			if(s[i]=='u')
				flag++;
		}
		printf("u:%d\n",flag);
		if(n>0)
			printf("\n");	
	}
	return 0;
}

然后这样写也行:

#include<stdio.h>
#include<string.h>
int main()
{
    char s[110];
    int n,len,a,b,c,d,e,i;
    scanf("%d",&n);
    getchar();
    while(n--)
    {
        gets(s);
        len=strlen(s);
        a=b=c=d=e=0;
        for(i=0;i<len;i++)
        {
            if(s[i]=='a')
                a++;
            if(s[i]=='e')
                b++;
            if(s[i]=='i')
                c++;
            if(s[i]=='o')
                d++;
            if(s[i]=='u')
                e++;
        }
        printf("a:%d\n",a);
        printf("e:%d\n",b);
        printf("i:%d\n",c);
        printf("o:%d\n",d);
        printf("u:%d\n",e);
        if(n>0)
            printf("\n");    
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/wan_ide/article/details/81104780