首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数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
2017-11-27
70
问题
请编写函数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的花括号中填入你编写的若干语句。
#include
#define N 80
int fun(int a[], int n)
{
}
main ()
{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 ();
printf("The original data :\n");
for(i=0; i
a
);
n=fun(a,n);
printf("\n\nThe data after deleted:
\n");
for(i=0;i
printf("%3d",a
);
printf("\n\n");
NONO();
}
void NONO ()
{/*请在此函数内打开文件,输入测试数
据,调用fun函数,输出数据,关闭文件。
*/
FILE *rf, *wf; int a[N], n, i, j ;
rf = fopen("in.dat","r");
wf = fopen("out.dat", "w") ;
for(i = 0 ; i < 5 ; i++) {
fscanf(rf, "%d", &n);
for(j = 0 ; j < n ; j++)
fscanf(rf, "%d", &a[j]);
n = fun (a, n);
for(j = 0 ; j < n ; j++)
fprintf (wf, "%4d", a[j]);
fprintf(wf, "\n");
}
f close (rf); f close (wf) ;
}
选项
答案
int i,t,j=0,*p=a; t=p[0]; //设置临时变量t初值指向第 一数组值 for(i=0;i<=n;i++) if(t==p[i]) //当临时变量与数组 中的某个值相同则跳出,比较下一个元素 ; else //如果临时变量与数组中值 不同,则对临时变量重新赋值 {a[j]=t; t=p[i]; j++;} if(i>=n) a[j]=t; return j;
解析
(1)首先,设置一个临时变量,初值设置为一维数组的第一个元素。
(2)然后,依次将数组的元素与临时变量比较,如果相同,则继续取数组下一个元素与临时变量比较;如果不同,则将临时变量的值赋值到数组的第一个元素,同时将此与临时变量不同的数组元素赋值给临时变量。
(3)循环执行,直到所有的数据处理完毕。
转载请注明原文地址:https://kaotiyun.com/show/g6xp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
当运行以下程序时,输入abcd,程序的输出结果是:()。insert(charstr[]){inti;i=strlen(str);while(i>0){str[2*i]=str[i];str[2*i-1
以下程序运行后的输出结果是()。main(){intx,a=1,b=2,c=3,d=4;{intx,a=1,b=2,c=3,d=4;x=(a<B)?a:b;x=(a<C)?x:C;x=(d>x)?x:d;
()的任务是诊断和改正程序中的错误。
有以下程序:mian(){inti,j;for(i=1;i<4;i++){for(j=i;j<4;j++)printf("%d*%d=%d",i,j,i*j);printf("\n");}}
以下程序的输出结果是()。#include<stdlib.h>main(){char*s1,*s2,m;s1=s2=(char*)malloc(sizeof(char));*s1=15;*s2=2
有以下结构体说明和变量定义,如图所示,指针p、q、r分别指向此链表中的三个连续节点。structnode{intdata;structnode*next;}*P,*q,*r;现要将q所指节点从链表中删除,同时要保持链表的连续,
设有以下程序段structMP3{charname[20];charcolor;floatprice;}std,*ptr;ptr=&std;若要引用结构体变量std中的color成
以下选项中,能表示逻辑值“假”的是
设有以下语句charch1,ch2;scanf(“%c%c”,&ch1,&ch2);若要为变量ch1和ch2分别输入字符A和B,正确的输入形式应该是
以下有4组用户标识符,其中合法的一组是()。
随机试题
化脓性脑膜炎合并硬膜下积液的治疗方法是
自律性最高的是传导速度最快的是
相对于东晋和南朝的园林,唐宋至明清时期的园林呈现出新特征,对此下列哪一项描述不正确?
合理规避个人所得税的首选工具可以是()。
根据《公司法》等相关法律规定,公司利润分配的顺序是()。
Newtechnologylinkstheworldasneverbefore.Ourplanethasshrunk.It’snowa"globalvillage"wherecountriesareonlysec
拘留是公安机关依法对违反治安管理的人强制关押在专门处所,在一定时间内限制其人身自由以示惩戒的一种行政处罚方法。它是治安管理处罚中最重的一种。()
行政许可申请只能通过当场提交的形式提出。()
第一次国共合作正式形成的标志是()。
陈女士在某网店购买了一套护肤用品,合计600元,与卖家约定商品到达后2日内付款。这里,货币执行的职能是
最新回复
(
0
)