首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数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
2018-09-10
51
问题
请编写函数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
注意:请勿改动main函数和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
试题程序:
#include<stdio.h>
#define N80
int fun(int a[],int n)
{
}
void main()
{
FILE*wf;
int a[N]=t2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10,10},i,n=20;
printf("The original data:\n");
for(i=0;i<n;i++)
printf("%3d",a
);
n=fun(a,n);
printf("\nThe data after deleted:\n");
for(i=0;i<n;i++)
printf("%3d",a
);
printf("\n");
/****************/
wf=fopen("out.dat","w");
for(i=0;i<n;i++)
fprintf(wf,"%3d",a
);
felose(wf);
/****************/
}
选项
答案
int fun(int a[],int n) { int i,j=1; f10r(i=1;i<n;i++) if(a[j-1]!=a[i])/*若该数与前一个数不相同,则要保留*/ a[j++]=a[i]; return j;/*返回不相同数的个数*/ }
解析
该程序的流程是:定义变量i和j,其中j用于控制删除后剩下的数在数组中的下标,i用于搜索原数组中的元素。j始终是新数组中最后一个元素的下一个元素的下标,所以if语句中的条件是a[j-1]!=a
,其中a[j-1]就是新数组中的最后一个元素,若条件成立,则表示出现了不同的值,所以a
要保留到新数组中。
注意:本题中i和j的初值都要从1开始,该算法只能用于数组已排序的题目中。
转载请注明原文地址:https://kaotiyun.com/show/7Vxp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
下面fun函数的功能是将形参x的值转换成二进制数,所得二进制数的每一位数放在数组中返回,二进制数的最低位放在下标为0的元素中,其他依此类推。请填空。Fun(intx,intb[]){intk=0,r;do{r=x%2
下列关于线性表的叙述中,不正确的是()。
两种基本测试方法中,()测试的原因之一是保证所测试模块中每一个独立路径至少要执行一次。
有以下程序:main(){intx=0,y=0,i;for(i=1;++i){if(i%2==0){x++;continue;}if(i%5==0){y++;break;}}printf("
下列程序执行后输出的结果是______。intd=1;fun(intp){intd=5;d+=p++;printh("%d,",d);}main(){
结构化分析方法是面向()的自顶向下、逐步求精进行需求分析的方法。
若以“a+”方式打开一个已存在的文件,则下列叙述正确的是()。
本程序用冒泡法对数组a[]的元素从大到小排序,请在程序空白处填空。voidbubble(inta[],intn){intid,max,temp;max=n-1;do{j=0;f
一棵二叉树中共有70个叶子结点与80个度为1的结点,则该二叉树中的总结点数为
设有定义:inta=0,b=1;,以下表达式中,会产生“短路”现象,致使变量b的值不变的是()。
随机试题
()在沉积岩层中,心滩多呈环状砂层体出现。
中共一大选举的党的领导机构成员有()
科学把很大的热情投入到了对忧郁的解析而不是对开怀喜悦的理解当中。研究者们早就知道,愤怒和压抑会让我们生病,甚至死亡。可是,他们猜想,像乐观、好奇和狂喜( )那种想张开臂膀,为春天的甜蜜而高歌一曲的冲动( )这类的感觉,不仅使人生值得留恋,而且会使寿命极
男性,74岁。体重60kg,全胃切除术后5天,大量肠液自腹腔引流管引出,左上腹疼痛。查体:左上腹压痛,无肌张。该病人热量每天基本需要量是
在网络计划的工期优化过程中,为了有效地缩短工期,应选择()作为压缩对象。
各国法律都认为,凡受欺诈而订立合同时,蒙受欺骗的一方可以撤销合同或主张合同无效。()
某明星在虚假广告中向消费者推荐食品,使消费者的合法权益受到损害,他应该()。
请从以下供选择的答案中为index.asp文档程序中(1)~(5)处空缺部分选择正确答案。(1)A.CreateObjectB.ConnectC.ExecuteSQLD.Open()(2)A.<body>B.<ht
假设数码相机使用的存储卡容量是1GB,数据压缩比平均是4,那么它一次可连续拍摄65536色的1024×1024,分辨率的彩色相片大约多少张?
许先生正在厦门大学读博士学位。
最新回复
(
0
)