统计元音

统计每个元音字母在字符串中出现的次数。
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
问题来源:https://vjudge.net/problem/HDU-2027
问题分析:对应ACSII表,找到对应元音,然后求余(或可以对96求余)。
代码分析:利用while循环,判断输入的行数,利用for循环访问每一个字符,然后用switch循环求每行中元音的个数。
AC通过的代码:

#include 
using namespace std;
int main()
{
    int n, i;
    cin >> n;
    cin.ignore();
    while (n--)
    {
        char s[100];
        gets(s);
        int m = strlen(s), a[5] = { 0 };
        for (int k = 0; k < m; k++)
        {
            switch (s[k] % 64)
            {
            case 33:a[0]++; break;
            case 37:a[1]++; break;
            case 41:a[2]++; break;
            case 47:a[3]++; break;
            case 53:a[4]++; break;
            }
        }
        cout << "a:" << a[0] << endl;
        cout << "e:" << a[1] << endl;
        cout << "i:" << a[2] << endl;
        cout << "o:" << a[3] << endl;
        cout << "u:" << a[4] << endl;
        if (n) cout << endl;
    }
    return 0;
}

你可能感兴趣的:(统计元音)