首页 > 学院 > 开发设计 > 正文

编程练习3.1

2019-11-14 09:11:17
字体:
来源:转载
供稿:网友

题目:编写函数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);	}


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表