/*编写函数int stat(int a[],int n,int c[][2]).a指向的数组中保存了由n个1位整数组成的数列(n为偶数)。函数从前至后依次将a数组中每两个相邻元素拼成一个不超过2位的整数,从而生成有n/2个元素组成的整数数列;统计该数列中不同整数各自出现的次数,并将统计结果保存到C指向的二维数组中。函数返回不同整数的个数*/
#include <stdio.h>
#define N 20
int stat(int a[],int n,int c[][2])
{
int i = 0;
int j = 0;
int k = 0; //统计2位数整数的个数
int buffer[N] = {0}; //存放2位数整数数组
int count = 0;
for(i = 0;i < n;i++)
{
buffer[k] = a[i]*10+a[++i];
k++;
}
c[count][0] = buffer[0];
c[count][1] = 1;
for(i = 0;i < k-1;i++)
{
for(j = i+1;j < k;j++)
{
if(buffer[j] != buffer[i])
{
c[j][0] = buffer[j];
c[j][1] = 1;
}
else
{
c[i][1]++;
}
}
}
count = j;
for(i = 0;i < count-1;i++) //相同的数删除
{
for(j = i+1;j < count;j++)
{
if(c[j][0] == c[i][0])
{
c[j][0] = c[j+1][0];
c[j][1] = c[j+1][1];
count--;
}
}
}
for(i = 0;i < count;i++)
{
for(j = 0;j < 2;j++)
{
printf("%d ",c[i][j]);
}
printf("\n");
}
}
int main()
{
int a[N] = {0};
int a_count = 0;
int c[N][2] ={{0},{0}};
int i = 0;
printf("please input a_count:\n(偶数):\n");
scanf("%d",&a_count);
printf("please input a:\n");
for(i = 0;i < a_count;i++)
{
scanf("%d",&a[i]);
}
stat(a,a_count,c);
return 0;
}
编写函数int stat(int a[],int n,int c[][2]).a指向的数组中保存了由n个1位整数组成的数列(n为偶数)。
最新推荐文章于 2020-12-10 14:09:08 发布