首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
函数fun的功能是:把形参a所指数组中的最大值放在a[0]中,接着求出a所指数组中的最小值放在a[1]中:再把a所指数组元素中的次大值放在a[2]中,把a数组元素中的次小值放在a[3]中;其余以此类推。例如:若a所指数组中的数据最初排列为:1、4、2、3、
函数fun的功能是:把形参a所指数组中的最大值放在a[0]中,接着求出a所指数组中的最小值放在a[1]中:再把a所指数组元素中的次大值放在a[2]中,把a数组元素中的次小值放在a[3]中;其余以此类推。例如:若a所指数组中的数据最初排列为:1、4、2、3、
admin
2018-09-27
53
问题
函数fun的功能是:把形参a所指数组中的最大值放在a[0]中,接着求出a所指数组中的最小值放在a[1]中:再把a所指数组元素中的次大值放在a[2]中,把a数组元素中的次小值放在a[3]中;其余以此类推。例如:若a所指数组中的数据最初排列为:1、4、2、3、9、6、5、8、7,则按规则移动后,数据排列为:9、1、8、2、7、3、6、4、5。形参n中存放a所指数组中数据的个数。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
1 #include<stdio.h>
2 #defihe N 9
3 /**********found**********/
4 void fun(int ___1___,int n)
5 { int i,j,max,min,px,pn,t;
6 /**********found**********/
7 for(i=0;i<n-1;i+=___2____)
8 { max=min=a
;
9 px=pn=i;
10 /**********found**********/
11 for(j=___3___;j<n; j++)
12 { if(max<a[j])
13 { max=a[j];px=j;}
14 if(min>a[j])
15 { min=a[j];pn=j;}
16 }
17 if(px!=i)
18 (t=a
;a
=max;a[px]=t;
19 if(pn==i) pn=px;
20 }
21 if(pn!=i+1)
22 {t=a[i+1];a[i+1]=min;a[pn]=t;}
23 }
24 }
25 main()
26 {int b[N]={1,4,2,3,9,6,5,8,7},i;
27 printf(’’\nThe original data:\n’’);
28 for(i=0;i<N;i++)printf(’’%4d’’,b
);
29 printf(’’\n’’);
30 fun(b,N);
31 printf(’’\nThe data after moving:\n’’);
32 for(i=0;i<N;i++)printf(’’%4d’’,b
);
33 printf(’’\n’’);
34 }
选项
答案
(1)*a (2)2 (3)i+1
解析
本题中函数的功能是将数组中的元素下标为偶数的元素按照从大到小排序,下标为奇数的元素按照从小到大排序,相当于2个排序过程。在fun函数中,采用选择排序法进行排序,分别用max和min存储每次寻找的最大值和最小值,px和pn记录每次查找到的最大值和最小值的下标位置。
第一空:主函数内fun函数的调用“fun(b,N);”,其中,b为整型数组名,故fun函数的第一参数为整型指针,又根据“max=a[j]”可知第一个参数名为a,故第一空处为“*a”。
第二空:根据题意a所指数组中的最大值放在a[0]中,接着求出a所指数组中的最小值放在a[1]中;再把a所指数组元素中的次大值放在a[2]中,把a数组元素中的次小值放在a[3]中,升序排序和降序排序的下标变化是每次在前一次的基础上+2,即a[0]、a[2]、a[4]…降序排序,a[1]、a[3]、a[5]…升序排序,故第二空应为“2”。
第三空:选择排序法中的升序排序,首先从数组中挑选一个最小的元素,把它和第一元素交换,接着从剩下的n-1个元素中再挑出一个最小的元素,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。故内层循环变量j应该从i+1开始。因此,第三空处应为“i+1”。
转载请注明原文地址:https://www.kaotiyun.com/show/byxp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有如下程序: main() {char ch[2][5]={"6937","8254"},*p[2]; int i,j,s=0; for(i=0;i<2;i++)p[i]=ch[i]; for(i=0;i<2;i++) for(j=0;p[i][j]!=’
有定义语句:intb;charc[10];,则正确的输入语句是()。
下面四个选项中,不属于数据库管理系统提供的数据语言的是
以下程序段中,不能正确赋字符串(编译时系统会提示错误)的是
下面程序的运行结果是【】。#include<stdio.h>#defineSIZE12main(){chars[SIZE];inti;for(i=0;i<SIZE;i++)s[i]=’A’+i+321
以下叙述中错误的是()。
结构化分析方法是面向()的自顶向下、逐步求精进行需求分析的方法。
下列叙述中,不属于软件需求规格说明书的作用的是______。
在树形结构中,树根结点没有【】。
已知8个数据元素为(34,76,45,18,26,54,92,65),按照依次插入结点的方法生成一棵二叉排序树后,最后2层上的结点总数为______。
随机试题
A.大肠杆菌B.葡萄球菌C.人乳头瘤病毒D.淋球菌E.腮腺炎病毒感染子宫颈后常侵入子宫颈深处的病原生物是
A、呼吸表浅、双吸气B、呼吸快,有鼻翼扇动、三凹征C、呼出气体有烂苹果味D、吸气性呼吸困难E、呼气性呼气困难上呼吸道梗阻
A.定期考核B.接受培训和继续医学教育C.继续执业D.注销注册E.予以取缔考核不合格,暂停执业活动期满,再次进行考核,仍不合格的,由县级以上卫生行政部门()
男,36岁。车祸头部受伤。伤后不省人事约半小时,清醒后诉头痛、恶心、呕吐,4小时后再次昏迷。首先考虑()。
下列选项关于甲律师事务所的行为的判断中错误的是:()。如果千叶公司是汪、钱、潘、刘共同投资设立的有限合伙企业,其中汪、钱为普通合伙人,潘、刘为有限合伙人。后因该合伙企业长期拖欠供货商货款,企业资产不足以清偿到期债务。依照我国相关法律的规定,下列
贷款经办行贷后管理和检查工作包括()。
企业得到减免的增值税应包括在利润总额中。()
A.前牙区出现间隙,前牙切缘和磨牙面磨耗明显B.前牙区出现间隙,前牙切缘和磨牙面无明显磨耗C.最后磨牙远中面平齐D.磨牙呈中性关系E.浅覆,深覆盖4~6岁儿童,的特征有()。
对于美国人口总体来说平均的期望寿命是73.9岁,但是在夏威夷出生的小孩将平均活到77岁,而那些在路易斯安那州出生的小孩将平均活到71.7岁。如果一对从路易斯安那州来的新婚夫妇在夏威夷开始他们的家庭生活,那么,他们的孩子预期将比他们留在路易斯安那州的情况下活
Strategyandcultureareamongtheprimaryleversattopleaders’disposalintheirnever-endingquesttomaintainorganizationa
最新回复
(
0
)