首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
由N个有序整数组成的数列已放在一维数组中,下列给定程序中函数fun的功能是:利用折半查找法查找整数m在数组中的位置。若找到,返回其下标值;否则,返回—1。 折半查找的基本算法是:每次查找前先确定数组中待查的范围low和high(low<high),然后用m
由N个有序整数组成的数列已放在一维数组中,下列给定程序中函数fun的功能是:利用折半查找法查找整数m在数组中的位置。若找到,返回其下标值;否则,返回—1。 折半查找的基本算法是:每次查找前先确定数组中待查的范围low和high(low<high),然后用m
admin
2019-04-14
51
问题
由N个有序整数组成的数列已放在一维数组中,下列给定程序中函数fun的功能是:利用折半查找法查找整数m在数组中的位置。若找到,返回其下标值;否则,返回—1。
折半查找的基本算法是:每次查找前先确定数组中待查的范围low和high(low<high),然后用m与中间位置(mid)上元素的值进行比较。如果m的值大于中间位置元素的值,则下一次的查找范围落在中间位置之后的元素中;反之,下一次的查找范围落在中间位置之前的元素中。直到low>high,查找结束。
请改正程序中的错误,使它能得出正确的结果。
注意:不得增行或删行,也不得更改程序的结构!
试题程序:
#include <stdio.h>
#define N 10
/* * * * * * found * * * * * */
void fun(int a[],int m)
{
int low=0,high=N—1,mid;
while(low< =high)
{
mid=(low+high)/2;
if(m<a[mid])
high=mid—1;
/* * * * * * found * * * * * */
else If(m>a[mid])
low=mid+1;
else return(mid);
}
return(—1);
}
main()
{
int i,a[N]={—3,4,7,9,13,45,67,89,100,180},k,m;
printf(″a数组中的数据如下:″);
for(i=0;i<N;i+ +)
printf(″%d″,a
);
printf(″Enter m:″);
scanf(″%d″,&m);
k=fun(a,m);
if(k> =0)
printf(″m=%d,index=%d\n″,m,k);
else
prinff(″Not be found!\n″);
}
选项
答案
(1)int fun(int a[],int m)或fun(int a[],int m) (2)else if(m>a[mid])
解析
本题考查:折半查找算法;函数定义;if…else语句。
(1)fun(int a[],int m)函数的返回值为int类型,所以定义函数时,函数的返回类型不能是
void,而是int类型。这里int可以省略,若省略函数类型标识符,系统将默认为int型。
(2)else If(m> a[mid])中,关键字if需要区别大小写,大写是错误的。
说明:折半查找算法,将数列按有序化(递增或递减)排列,查找过程中采用跳跃式方式查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小于该中点元素,则将待查序列缩小为左半部分,否则为右半部分。通过一次比较,将查找区间缩小一半。
转载请注明原文地址:https://kaotiyun.com/show/R2Rp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
诊断和改正程序中错误的工作通常称为【】。
有以下程序#inculdeintFun(){ststicintx=1;x*=2;returnx;}main(){inti,s=1;For(i=1;I
有以下程序 main(int argc,char *argv[]) { int n=0,i; for(i=1;i<argc;i++) n=n*10+ *argv[i] ’0’; printf("%d\n",n); }
若有如下程序:main(){staticchar*a[3]={"123","456","789");char**b;b=a;++b;printf("%s,%s\n",*a,*a+1);printf(
以下程序的输出结果是______。main(){inta[4][4]={{1,3,5},{2,4,6},{3,5,7}};printf("%d%d%d%d\n",a[0][3],a[1][2],a[2][1];a
下面程序的运行结果是______。main(){unsigneda=3,b=10;printf("%d\n",a<<2|b>>1);}
以下程序调用findmax函数返回数组中的最大值findmax(inE*a,intn){int*p,*s;for(p=a,s=a;p-a<n;p++)if(______)s=p;ret
下面程序的执行结果是______。main(){charstr[]="quert?",*p=str;while(putchar(*p++)!=’?’);}
有以下程序:main(){inti;for(i=0;i<3;i++)switch(i){case0:prinft("%d",i);Case2:prinft("%d",i);def
随机试题
有一副对联,上联是“橘子洲,洲旁舟,舟行洲不行”;下联是“天心阁,阁中鸽,鸽飞阁不飞”。这形象地说明了运动和静止是相互依存的,静止是
与目赤肿痛的发生密切相关的经脉是()
简述在Excel中,将单元格中数据旋转45°的操作步骤。
此时进行的胎心监护属于哪种类型( )出现频繁晚期减速,最佳处理方法是( )
树木:砍伐()
王某与他人合作投资成立了一家有限责任公司,王某任法定代表人。后来公司倒闭,公司资产不足以偿还债务。公司的债权人要求王某偿还不足部分。下列说法正确的是:( )
设a为常数,则级数【】
TCP是一个面向连接的协议,它提供连接的功能是(14)的,采用(15)技术实现可靠数据流的传送。为了提高效率,又引入了滑动窗口协议,协议规定重传(16)的分组,这种分组的数量最多可以(17),TCP协议采用滑动窗口协议来解决了(18)。
如果在命令窗口执行命令:LIST名称,主窗口中显示:记录号名称1电视机2计算机3电话线4电冰箱5电线假定名称字段为字符型、宽度为6,那么下面程序段的输出结果是()。G
Afteryearsinthewilderness,theterm"artificialintelligence"(AI)seemspoisedtomakeacomeback.AIwasbiginthe1980sb
最新回复
(
0
)