编程练习3.1
2017-02-05 20:19
148 查看
题目:编写函数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);
}
#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);
}
相关文章推荐
- C++primer plus第六版课后编程练习答案3.1
- C++ Primer Plus 第六版 所有章节课后编程练习答案
- C++ Primer Plus (第六版) 编程练习3.7
- 《C程序设计的抽象思维》1.9编程练习
- C++ Primer Plus第六版编程练习8.2解答
- <<C和指针>>第1章之编程练习心得20140704
- 网络编程练习-TCP socket
- C Primer Plus第二章编程练习
- 编程小练习
- C ++ Primer Plus 第六版 第十一章编程练习答案
- shell 编程实例练习(一)
- C++ Primer Plus第六版编程练习8.6解答
- C语言程序设计进阶 翁恺 第4周编程练习
- UFLDL教程练习答案一(稀疏自编码器和矢量化编程实现)
- 编程练习- 链表题目-反序,合并
- 记录——《C Primer Plus (第五版)》第十章编程练习第五题
- C primer plus(编程练习)file-9.11-2
- C primer plus(编程练习)file-9.11-5
- 【编程小练习】删除字符串中的子串
- C语言编程(练习1:分支和跳转 )