编写函数int stat(int a[],int n,int c[][2])。
a指向的数组中保存了由n个1位整数组成的数列(n为偶数)。函数从前至后依次将a数组中每两个相邻元素拼成一个不超过2位的整数,从而生成有n/2个元素组成的整数数列;统计该数列中不同整数各自出现的次数,并将统计结果保存到c指向的二维数组中。函数返回不同整数的个数。
#include <stdio.h>
int stat(int a[],int n,int c[][2]);
int main()
{
int n,i;
int a[255];
int c[255][2]; //c用来存放数字和数字的个数
printf("enter n(n is even):");
scanf("%d",&n);
printf("enter %d numbers:\n",n);
for(i = 0;i < n;i++)
{
scanf("%d",&a[i]);
}
stat(a,n,c);
return 0;
}
int stat(int a[],int n,int c[][2])
{
int b[255];
int i, k, count;
int j = 0, t = 0;
for(i = 0;i < n;i += 2)
{
b[j++] = 10 * a[i] + a[i+1]; //b存放合并后新数组
}
for(i = 0;i <= j;i++)
{
count = 1; //要找的数先算一个,每次开始找另一个数的时候都要重新置1;
if(b[i] != 0)
{
for(k = 0;k <= j;k++)
{
if(b[i] == b[k] && i != k) //不和本身比
{
count++;
b[k] = 0; //找过的相同的数置零后面不再找
}
}
c[t][0] = b[i]; //找到的数和个数放在c数组里面
c[t][1] = count;
t++;
}
}
for(i = 0;i < t; i++)
{
for(j = 0;j < 2;j++)
{
printf("%d ",c[i][j]);
}
printf("\n");
}
}