编写函数int stat(int a[],int n,int c[][2])

   编写函数int stat(int a[],int n,int c[][2])

   a指向的数组中保存了由n1位整数组成的数列(n为偶数)。函数从前至后依次将a数组中每两个相邻元素拼成一个不超过2位的整数,从而生成有n/2个元素组成的整数数列;统计该数列中不同整数各自出现的次数,并将统计结果保存到c指向的二维数组中。函数返回不同整数的个数。


#include <stdio.h>


int stat(int a[],int n,int c[][2]);


int main()
{
int n,i;
int a[255];
int c[255][2];       //c用来存放数字和数字的个数


printf("enter n(n is even):");
scanf("%d",&n);
printf("enter %d numbers:\n",n);

for(i = 0;i < n;i++)
{
        scanf("%d",&a[i]);
}


stat(a,n,c);


    return 0;
}


int stat(int a[],int n,int c[][2])
{
        int b[255];
int i, k, count;
int j = 0, t = 0;


for(i = 0;i < n;i += 2)
{
b[j++] = 10 * a[i] + a[i+1];   //b存放合并后新数组
}


for(i = 0;i <= j;i++)
{
count = 1;       //要找的数先算一个,每次开始找另一个数的时候都要重新置1;
if(b[i] != 0)     
{
                        for(k = 0;k <= j;k++)
{
  if(b[i] == b[k] && i != k) //不和本身比
{
  count++;
b[k] = 0;    //找过的相同的数置零后面不再找
}
}
    
                        c[t][0] = b[i];   //找到的数和个数放在c数组里面
c[t][1] = count;
t++;
}
}


for(i = 0;i < t; i++)
{
for(j = 0;j < 2;j++)
{
printf("%d ",c[i][j]);
}
printf("\n");
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值