background image

j++;
}
for(i=0;i<j;i++)
if(x%t[i]==0)
{
pp[k]=t[i];
k++;
}
*n=k;
}

4: 第 4

 

题 请编写一个函数 void fun(char *tt,int pp[]),统计在 tt 字符中"a"到"z"26 各字母各自

出现的次数,并依次放在 pp

 

所指的数组中。

答案:
void fun(char *tt, int pp[])
{
int i;
for (i=0;i<26;i++)
pp[i]=0;
while (*tt)
{
switch (*tt)
{
case 'a': pp[0]++;break;
case 'b': pp[1]++;break;
case 'c': pp[2]++;break;
case 'd': pp[3]++;break;
case 'e': pp[4]++;break;
case 'f': pp[5]++;break;
case 'g': pp[6]++;break;
case 'h': pp[7]++;break;
case 'i': pp[8]++;break;
case 'j': pp[9]++;break;
case 'k': pp[10]++;break;
case 'l': pp[11]++;break;
case 'm': pp[12]++;break;
case 'n': pp[12]++;break;
case 'o': pp[14]++;break;
case 'p': pp[15]++;break;
case 'q': pp[16]++;break;
case 'r': pp[17]++;break;
case 's': pp[18]++;break;
case 't': pp[19]++;break;