编写函数int stat(int a[],int n,int c[][2])。a指向的数组中保存了由n个1位整数组成的数列(n为偶数)。函数从前至后依次将a数组中每两个相邻元素拼成一个不超过2位的整数,从而生成有n/2个元素组成的整数数列;统计该数列中不同整数各自出现的次数,并将统计结果保存到c指向的二维数组中。函数返回不同整数的个数。
/*****************************************************
copyright (C), 2016-2017, Lighting Studio. Co., Ltd.
File name:
Author:luoye Version:0.1 Date:
Description:
Funcion List:
*****************************************************/
#include <stdio.h>
int stat(int a[], int n, int c[][2])
{
int i, j, k;
int count = n/2; //count为不同整数的个数
for( i = 0, j = 0; i < n ; j++, i = i + 2) //将相邻的两个数并为一个数
{
c[j][0] = a[i] * 10 + a[i+1];
c[j][1] = 1;
}
// 找出相同数的个数
for( i = 0; i < n/2; i++)
{
for( j = i + 1; j < count ;j++)
{
if( c[i][0] == c[j][0])
{
c[i][1]++;
for( k = j ; k < count; k++) //如果有相同数,就把第二个数删去,使数组没有相同的数。
{
c[k][0] = c[k+1][0];
c[k][1] = c[k+1][1];
}
count--;
}
j--;
}
}
return count;
}
int main()
{
int a[10] = {0,1,1,3,1,3,4,5,7,2}; //输入数组元素
int c[5][2];
int i, n;
n=stat(a,10,c); //返回不同整数个数
for( i = 0; i < n; i++)
{
printf("%d:%d\n",c[i][0],c[i][1]);
}
return 0;
}