题目:编写函数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 j,u,k,i,count; for(j = 0; j < n; j++) //将相邻两位数组合在一起 { u = 2 * j; //每次需要加2 c[j][0] = a[u] *10 + a[u + 1]; } for(k = 0; k < (n/2); k++) //依次对其中的数和之后的比较 { count = 1; if(c[k][0] == 100) //去除比较过相同的数字,因为组合数最多为两位 continue; for(i = (k + 1); i < (n/2); i++) { if(c[k][0] == c[i][0]) //判断两数是否相等 { count++; //记录相等数的个数并将其置为100舍弃 c[i][0] = 100; } } PRintf("%d %d/n",c[k][0],count); }}int main(){ int a[100],n,c[10][2],i; printf("Please input the total:/n"); scanf("%d",&n); printf("Please input the numbers:/n"); for(i = 0; i < n; i++) scanf("%d",&a[i]); //将数依次存入数组 stat(a,n,c); }
新闻热点
疑难解答