统计每个元音字母在字符串中出现的次数。
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
上面是题目,要求找到A E I O U的数量
AC代码:
#include<iostream>
#include<stdlib.h>
using namespace std;
int main()
{
void write(int*x, int*y, int*z, int*r, int*t);
int a;
while (cin >> a)
{
int i;
int**p = new int*[a];
int j;
for (j = 0; j < a; j++)
{
p[j] = new int[5];
memset(p[j], 0, 20);
}
for (i = 0; i < a; i++)
{
write(&p[i][0], &p[i][1], &p[i][2], &p[i][3], &p[i][4]);
}
int k;
for (k = 0; k < a; k++)
{
if (k != 0)
{
cout << endl;
}
cout << "a:" << p[k][0] << endl;
cout << "e:" << p[k][1] << endl;
cout << "i:" << p[k][2] << endl;
cout << "o:" << p[k][3] << endl;
cout << "u:" << p[k][4] << endl;
}
}
return 0;
}
void write(int*x, int*y, int*z, int*r, int*t)
{
int m;
char a[200];
cin >> a;
for (m = 0; m < 200; m++)
{
if (a[m] == '\0' || a[m] == '\n')
{
break;
}
if (a[m] == 'a')
{
*x += 1;
}
if (a[m] == 'e')
{
*y += 1;
}
if (a[m] == 'i')
{
*z += 1;
}
if (a[m] == 'o')
{
*r += 1;
}
if (a[m] == 'u')
{
*t += 1;
}
}
}
该题运用了for循环进行遍历,以及用new申请了自定义数量的地址。