编写函数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; }
