第二期白银组第八题

统计每个元音字母在字符串中出现的次数。
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
#include
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申请了自定义数量的地址。

你可能感兴趣的:(第二期白银组第八题)