未分类题

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-l,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,24,67,89,100,180},k,m;
printf ('a数组中的数据如下: ');
for(i=0;i<N;i++) printf('%d',a[i]);
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');
}

A.h>


【参考答案】

(1)错误:void fun(int a[]int m) 正确:int fun(int a[]int m)(2)错误:e......

(↓↓↓ 点击下方‘点击查看答案’看完整答案 ↓↓↓)
热门 试题

未分类题
打开考生文件夹4下的Word文档WORDl.DOC,其内容如下: 【WORDl.DOC文档开始】 绍兴东湖 东湖位于绍兴市东郊约3公里处,北靠104国道,西连城东新区,它以其秀美的湖光山色和奇兀实景而闻名,与杭州西湖、嘉兴南湖并称为浙江三大名湖。整个景区包括陶公洞、听湫亭、饮渌亭、仙桃洞、陶社、桂林岭开游览点。 东湖原是一座青实山,从汉代起,实工相继在此凿山采实,经过一代代实工的鬼斧神凿,遂成险峻的悬崖峭壁和奇洞深潭。清末陶渊明的45代子孙陶浚宣陶醉于此地之奇特风景而诗性勃发,便筑堤为界,使东湖成为堤外是河,堤内为湖,湖中有山,山中藏洞之较完整景观。又经过数代百余年的装点使东湖宛如一个巧夺天工的山、水、实、洞、桥、堤、舟楫、花木、亭台楼阁具全,融秀、险、雄、奇与一体的江南水实大盆景。特别是现代泛光照射下之夜东湖,万灯齐放,流光溢彩,使游客置身于火树银花不夜天之中而流连忘返。 【WORD1.DOC文档结束】 按要求对文档进行编辑、排版和保存: (1)将文中所有“实”改为“石”。 (2)将标题段文字(“绍兴东湖”)设置为二号蓝色空心黑体、倾斜、居中。 (3)设置正文各段落(“东湖位于……流连忘返。”)断后间距为0.5行,各段首字下沉2行 (距正文0.2厘米);在页面底端(页脚)居中位置插入页码。 2.打开考生文件夹4下的Word文档WORD2.DOC,其内容如下: 【WORD2.DOC文档开始】 姓名 数学 外语 政治 语文 平均成绩 王立 98 87 89 87 李萍 87 78 68 90 柳万全 90 85 79 89 顾升泉 95 89 82 93 周理京 85 87 90 95 【WORD2.DOC文档结束】 按要求完成下列操作并以原名保存:(1)将文档内提供的数据转换成6行6列的表格。设置表格居中、表格列宽为2厘米,行高为自动设置。计算各学生的平均成绩。(2)将表格外框线、第1行的下框线和第1列的右框线设置为1.5磅单实线,表格底纹设置为“灰度-15%”。