首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序中,函数fun的功能是:在任给给定的9个正整数中找出按升序排列时处于中间的数,将原数据序列中比该中间数小的数用该中间数替换,位置不变,在主函数中输出处理后的数据序:列,并将中间数作为函数值返回。 例如,有9个正整数:1 5 7 23 87 5
给定程序中,函数fun的功能是:在任给给定的9个正整数中找出按升序排列时处于中间的数,将原数据序列中比该中间数小的数用该中间数替换,位置不变,在主函数中输出处理后的数据序:列,并将中间数作为函数值返回。 例如,有9个正整数:1 5 7 23 87 5
admin
2019-03-06
31
问题
给定程序中,函数fun的功能是:在任给给定的9个正整数中找出按升序排列时处于中间的数,将原数据序列中比该中间数小的数用该中间数替换,位置不变,在主函数中输出处理后的数据序:列,并将中间数作为函数值返回。
例如,有9个正整数:1 5 7 23 87 5 8 21 45
按升序排列时的中间数为:8
处理后主函数中输出的数列为:8 8 8 23 87 8 821 45
请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
#define N 9
int fun(int x[])
(int i,j,k,t,mid,b[N];
for(i=0 ; i<N;i++)
b
=x
;
for(i=0;i<=N/2;i++)
{k=i;
for(j=i+1; j<N;j++)
if(b[k]>b[j])k=j;
if(k!=i)
{
/*********found*********/
t=b
;b
=
【1】
;
b[k]=t;
}
}
/*********found*********/
mid=b
【2】
;
for(i=0;i<N;i++)
/*********found*********/
if(x
【2】
mid)x
=mid;
return mid;
}
main()
{int i,x[N]={1,5,7,2 3,8 7,5,8,21,4 5};
for(i=0;i<N;i++)
printf("%d",x
);
printf("\nThe mid data is:%d\n",
fun(x));
for(i=0;i<N;i++)
printf("%d",x
);
printf("\n");
}
选项
答案
(1)b[k] (2)4或N/2 (3)<
解析
数组中的9个数任意排列,要找到按升序排列时处于中间位置的数,应首先对数组进行升序排列。因为只需找到中间位置的数即可,故不必对整个数组进行排序,只需要排列出数组的前半部分。找到中间数后,遍历原数组,将小于中间数的元素进行替换。
填空1:利用选择算法排序,先指定一个元素为最小,用这个数与其后的所有数进行比较,若找小于此数,则进行替换。此处考查替换操作。
填空2:元素mid存放中间位置的数,数组长度为9,因此中间元素数为b[4]。
填空3:遍历数组,当元素小于中间位置的数 (即mid)时,进行替换。
转载请注明原文地址:https://kaotiyun.com/show/PIRp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有以下函数intaaa(char*s){char*t=S;while(*t++);t--;return(t-s);}以下关于aaa函数的功能的叙述正确的是
有以下程序#includemain(){intC=O,k;for(k=1;k
下面程序main(){inty=9;for(;y>0;y--){if(y%3=0){printf("%d",--y);continue;
为了避免在嵌套的条件语句ifelse中产生二义性,C语言规定,else子句总是与()配对。
以下只有在使用时才为该类型变量分配内存的存储类型说明是()。
以下程序运行后的输出结果是______。fun(inta){intb=0;staticintc=3;b++;c++;return(a+b+c);}main()
执行程序时的输入为123456789,则程序的运行结果为_____________。#include“stdio.h”main(){inta,b;scanf(“%2d%*2d%1d”,&a,&b);
有如下程序main(){inti,sum;for(i=1;i<=3;sum++)sum+=i;printf("%d\n",sum);}该程序的执行结果是_____。
执行以下程序后,a,b的值分别为main(){ina,b,k=4,m=6,*p1=&k,*p2=&m;a=p1==&m;b=(*p1)/(*p2)+7;printf("a=%d\n",a);
若有说明“chars1[30]="abc",s2[]="defghi";”,则在使用函数stcat(s1,s2)后,结果是()。
随机试题
一个串的任意连续字符组成的子序列称为串的________,该串称为________。
最有可能进入电子商务市场的产品类型是
体液组成与作用的叙述,错误的是
化妆品直接使用于皮肤,最常见的不良影响是引起
A、玉女煎B、导赤散C、六一散D、黄连解毒汤E、竹叶石膏汤小便短赤,溲时热涩刺痛者,治疗应选用
股份有限公司董事会作出决议时,必须经全体董事的过半数通过。( )
某中学生在上网查询资料时,发现有人正在利用国际互联网泄露国家重要的经济情报。他及时将此事报告了有关部门。这名中学生履行了()。
回避制度:是指与刑事案件有某种利害关系或其他特殊关系的司法工作人员,包括侦查人员、检察人员、审判人员、书记员、鉴定人、翻译人员等,不能参加该案件处理工作的一项诉讼制度。在某一案件中,下列人员可以不回避的是()。
离婚后,无过错方有权请求赔偿的情形不包括()。
求.
最新回复
(
0
)