首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数fun,函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数己按由小到大的顺序排列,函数返回删除后数组中数据的个数。 例如,一维数组中的数据是:2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10
请编写函数fun,函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数己按由小到大的顺序排列,函数返回删除后数组中数据的个数。 例如,一维数组中的数据是:2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10
admin
2019-03-19
36
问题
请编写函数fun,函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数己按由小到大的顺序排列,函数返回删除后数组中数据的个数。
例如,一维数组中的数据是:2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10。
删除后,数组中的内容应该是:2 3 4 5 6 7 8 9 10。
注意:部分源程序在文件PROG1.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
1 #include<stdio.h>
2 #define.N 80
3 int fun(int a[],int n)
4 {
5
6 }
7 main()
8 {int a[N]={2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10,10},i,n=20;void NONO();
9 printf(’’The original data:\n’’);
10 for(i=0; i<n; i++)printf(’’%3d’’,a
);
11 n=fun(a,n);
12 printf(’’\n\nThe data after deleted:\n’’);
13 for(i=0;i<n;i++)printf(’’%3d’’,a
);printf(’’\n\n’’);
14 NONO();
15 }
16 void NONO()
17 {/*请在此函数内打开文件,输入测试数据,调用fun函数,输出数据,关闭文件。*/
18 FILE *rf,*wf;int a[N],n,i,j;
19 rf=fopen(’’in.dat’’,’’r’’);
20 wf=fopen(’’out.dat’’,’’w’’);
21 for(i=0;i<5;i++) {
22 fscanf(rf,’’%d’’,&n);
23 for(j=0 ; j<n; j++)fscanf(rf,’’%d’’,&a[j]);
24 n=fun(a,n);
25 for(j=0;j<n;j++) fprintf(wf,’’%4d’’,a[j]);
26 fprintf(wf,’’\n’’);
27 }
28 fclose(rf); fclose(wf);
29 }
选项
答案
1 int i,t,j=0,‘p=a; 2 t=p[0]; //设置临时变量t初值指向第一数组值 3 for(i=0;i<=n; i++) 4 if(t==p[i]) //当临时变量与数组中的某个值相同则跳出,比较下一个元素 5 ; 6 else //如果临时变量与数组中值不同,则对临时变量重新赋值 7 { a[j]=t; 8 t=p[i]; 9 j++;} 10 if(i>=n) a[j]=t; 11 return j;
解析
该程序功能是删去一维数组中所有相同的数,使之只剩一个。解题思路是,首先在函数中定义临时变量指向每一个元素,然后在循环过程中将临时值和其他元素进行比较,如果相同,那么跳过相同字符。
(1)首先,设置一个临时变量,初值设置为一维数组的第一个元素。
(2)然后,依次将数组的元素与临时变量比较,如果相同,则继续取数组下一个元素与临时变量比较:如果不同,则将临时变量的值赋值到数组的第一个元素,同时将此与临时变量不同的数组元素赋值给临时变量。
(3)循环执行,直到所有的数据处理完毕。
转载请注明原文地址:https://kaotiyun.com/show/n6Rp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
以下程序的输出结果是#includeintfun(intn,int*s){intf1,f2;if(n==0||n==1)*s=1;else{fun(n-1,&f1);fun(n-2,&f2);
数据库的故障恢复一般是由()来执行恢复。
最简单的交换排序方法是______。
软件工程研究的内容主要包括:【】技术和软件工程管理。
Jackson方法是一种面向______的结构化方法。
设树T的度为4,其中度为1,2,3,4的结点个数分别为4,2,1,1,则T中的叶子结点数为()。
数据处理的最小单位是
下面的程序实现的是指针p所指向的地址的n个数中,求出最大的和最小的数据,请填空。fun(int*p,intn){int*q;intmax,min;max=min=*p;for(q=p;【】
函数my_cmp()的功能是比较字符串s和t的大小,当s等于t时返回0,否则返回s和t的第一个不同字符的ASCII码差值,即s>t时返回正值,s
随机试题
声波传入内耳最主要的途径是
某人冬季用煤球取暖,但因烟囱阻塞而煤气中毒。病人处于昏迷状态,大小便失禁。抢救时首要措施是
全口义齿应一般在拔牙后多长时间进行修复
气虚血瘀型中风恢复期宜选
按照《建筑法》的规定,申请人以欺骗手段取得资质证书应承当的法律责任主要包括()。
结构性外汇理财产品的客户投资者面临的风险因素有()。
以下交易属于非正常交易的情况有()。
水至清则无鱼
简述概念形成的假说。
设函数y=f(x)由方程e2x+y-cos(xy)=e-1所确定,则曲线y=f(x)在点(0,1)处的法线方程为__________。
最新回复
(
0
)