首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数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
42
问题
请编写函数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全国计算机二级
相关试题推荐
不合法的main函数命令行参数表示形式是
下列的程序用来输出两个字符串前7个字符中对应相等的字符及其位置号,程序空白处应该填写的是()。#include<stdio.h>main(){chars1[]="chinese",s2[]="japnese";
以下程序运行时若要正确输出函数的入口地址和输入数的绝对值,应在程序空缺处填入的正确选项是abs(intx){if(x>=0)returnx;elsereturn-x;}main(){inty,z,(*
以下程序的输出结果为【】。main(){intk=1;white(k<=15)if(++k%3!=2)continue;elseprintf("%d",k);print
软件测试分为白箱(盒)测试和黑箱(盒)测试。基本路径测试方法属于()测试。
以下函数返回a所指数组中最小的值所在的下标值fun(int*a,intn){inti,j=0,p;p=j;for(i=j;i
在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是______。
随机试题
甲公司为增值税一般纳税人,增值税税率为17%,适用的企业所得税税率为25%。假定不考虑其他相关税费。确定计提坏账准备的比例为期末应收账款余额的5%。2014年1至11月末实现会计利润总额为750万元,递延所得税负债年初数为10万元,递延所得税资产年初数为7
行车中当驾驶人意识到机动车爆胎时,应在控制住方向的情况下采取紧急制动,迫使机动车迅速停住。
韦伯认为______是惟一纯粹的合法性类型。
服用十枣汤或舟车丸治疗鼓胀,药后会出现的副作用不包括
A.一次常用量B.3日常用量C.5日常用量D.7日常用量E.15日常用量根据《处方管理办法》为门诊患者开具的麻醉药品注射剂,每张处方为()。
下列各项中属于不确定性分析方法的是()。
港口与航道工程的图纸会审,参加单位应包括()。
施工成本分析就是根据会计核算、()和统计核算提供的资料,对施工成本的形成过程和影响成本升降的因素进行分析。
—IwastoldthatJackhadacaraccidentyesterday.—Ibelievenot.He______.
Essays,acollectionofshortarticlesonadiverserangeofsubjects,suchasdeathandmarriage,ambitionandatheism,iswrit
最新回复
(
0
)