编写函数int stat(int a[],int n,int c[][2])。a指向的数组中保存了由n个1位整数组成的数列(n为偶数)。函数从前至后依次将a数组中每两个相邻元素拼成一个不超过2位

    xiaoxiao2021-03-26  26

    /***************************************************** copyright (C), 2016-2017, Lighting Studio. Co., Ltd. File name: Author:王 Version:0.1 Date: Description: Funcion List: *****************************************************/ #include <stdio.h> int stat(int a[],int n,int c[][2]) { int i,j,k,flag; int m = 0; for(i = 0;i < n;i += 2) { a[j++] = a[i]*10 + a[i+1]; // 两个数合并为一个数 } for(i=0;i<n/2;i++) { flag = 0; for(j = 0;j<=i;j++) { if(a[i] == c[j][0]) // 判断所合并的数是否和之前的数一致,相同时 计数器 加1 ,并且关闭与其他数的比较 { c[j][1]++; flag = 1; } } if(flag == 0) // 如果合并的数与之前所有的数都不相同,那么将它存入数组C 中,并给定个数为 1 { c[m++][0] = a[i]; c[m-1][1] = 1; } } for(i=0;i<m;i++) printf("%d : %d \n",c[i][0],c[i][1]); // 输出合并后各不相同的数,并输出其个数 } int main() { int a[10]={1,2,1,2,5,6,7,8,9,1}; int c[5][2]; stat(a,10,c); return 0; }
    转载请注明原文地址: https://ju.6miu.com/read-661099.html

    最新回复(0)