首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
由N个有序整数组成的数列已放在一维数组中,下列给定程序中函数fun的功能是:利用折半杳找法查找整数m在数组中的位置。若找到,返回其下标值;否则,返回一1。 折半查找的基本算法是:每次查找前先确定数组中待查的范围low和high(low<high),
由N个有序整数组成的数列已放在一维数组中,下列给定程序中函数fun的功能是:利用折半杳找法查找整数m在数组中的位置。若找到,返回其下标值;否则,返回一1。 折半查找的基本算法是:每次查找前先确定数组中待查的范围low和high(low<high),
admin
2021-04-28
58
问题
由N个有序整数组成的数列已放在一维数组中,下列给定程序中函数fun的功能是:利用折半杳找法查找整数m在数组中的位置。若找到,返回其下标值;否则,返回一1。
折半查找的基本算法是:每次查找前先确定数组中待查的范围low和high(low<high),然后用m与中间位置(mid)上元素的值进行比较。如果m的值大于中间位置元素的值,则下一次的查找范围落在中间位置之后的元素中;反之,下一次的查找范围落在中间位置之前的元素中。直到low>high,查找结束。
请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
#define N 10
/**********found***********/
void fun(int a[],int m)
{ int low=0,high=N一1,mid;
while(low<=hLgh)
{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 printf(“Not be found!\n”),
}
选项
答案
(1)int fun(int a[],int m)或fun(int a[],int m) (2)else if(m>a[mid])
解析
(1)fun(int a[],int m)函数的返回值为int类型,所以定义函数时,函数的返回类型不能是void,而是int类型。这里int可以省略,若省略函数类型标识符,系统将默认为int型。
(2)else If(m>a[mid])中,关键字if需要区别大小写,大写是错误的。
转载请注明原文地址:https://kaotiyun.com/show/Qttp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有以下程序#include<stdio.h>main(){inti,j,m=55;for(i=1;i<=3;i++)for(j=3;j<=i.j++)m=m%j;printf(’’%d\n’’,m);}程序的运行结果是
有以下程序:#include<stdio.h>voidf(int*p,int*q);main(){intm=1,n=2,*r=&m;f(r,&n);printf(’’%d,%d’’,m,n);
以下关于逻辑运算符两侧运算对象的叙述中正确的是
有以下程序,程序的运行结果是#include<stdio.h>#include<stdlib.h>intfun(intn){int*p;p=(int*)malloc(sizeoffint));*p=n;return*p;main(){i
下面不属于软件测试实施步骤的是
有以下程序:#include<stdio.h>intadd(inta,intb){return(a+b);}main(){intk,(*f)(),a=5,b=10;f=add;…}则以下函数调用语句错误的是()。
以下叙述中正确的是
有如下嵌套的if语句if(a
下列特征中不是面向对象方法的主要特征的是()。
数据库系统在其内部具有3级模式,用来描述数据库中全体数据的全局逻辑结构和特性的是()。
随机试题
A、Cooperationandconcession.B、Exchangingdailynecessities.C、Equalityandmutualbenefit.D、Introducingadvancedtechnology.
随机变量X与Y独立,X~B(100,0.2),Y服从参数为的指数分布.则D(X-2Y)=_____.
视网膜微血管瘤位于哪一层
仲裁案件当事人甲公司与乙公司在案件审理过程中通过协商,就已经提交仲裁的争议达成和解协议。随后申请人甲公司撤回了仲裁申请。后甲公司反悔,此时甲、乙两公司的纠纷应如何解决?()
关于基坑开挖预留土层的说法,正确的是()。
某公司要提拔一名营销员作为片区经理,李明和其他四个竞争者都报名,其他四个竞争者都没有同时具备李明所有的优点。从以上断定能合乎逻辑地得出()。
手紙を書く()も、メールを送るのが一般的です。
Whenyoustarttalkingaboutgoodandbadmannersyouimmediatelystartmeetingdifficulties.Manypeoplejustcannotagreewhat
What’sthemainfeatureofthenewmethodofpayingformeals?
InatimeoflowacademicachievementbychildrenintheUnitedStates,manyAmericansareturningtoJapan,acountryofhigha
最新回复
(
0
)