大榕树——让我们共成长!
大榕树 myDrs.org
您的位置:大榕树 \ 编程       |  Logo语言   |  Pascal语言   |  信息学奥赛   |  高考保送    |  HTML版本
|  Pascal语言>>Pascal练习>>折半查找         本站全文搜索: 友情提示:

折半查找
http://www.mydrs.org  6/21/2001  大榕树


[问题描述] 这是一种效率高的查找方法,对一组有序数字进行查找.算法简单,即逐步缩小查找范围.
输入:[KEYBOARD] 输出:[SCREEN]
1 5 8 12 12 13 15 16 17 90 15
1 2 3 4 5 6 7 8 9 10 23
FOUND:7
NOT FOUND.


[问题分析] 由于数据按升序排列,故用折半查找最快捷.

program binsearch;

const max=10;
var num:array[1..max] of integer;
i,n:integer;

procedure search(x,a,b:integer);
var mid:integer;
begin
if a=b then
if x=num[a] then writeln('Found:',a) else writeln('Number not found')
else begin
mid:=(a+b) div 2;
if x>num[mid] then search(x,mid,b);
if x<num[mid] then search(x,a,mid);
if x=num[mid] then writeln('Found:',mid);
end;
end;

begin
write('Please input 10 numbers in order:');
for i:=1 to max do read(num[i]);
write('Please input the number to search:');
readln(n);
search(n,1,max);
end.

作 者:MQL
来 源:Pascal Zone
共有4003位读者阅读过此文

  • 上篇文章简单背包问题
  • 下篇文章快速排序

  • 发送邮件
    保存页面 打印文章 HTML版本 发表评论

    □- 近期热门文章 □- 相关文章
    1. NOIP2006竞赛大纲 [8306]
    2. 七类高中生具有保送资格 [5910]
    3. NOI2006获奖选手名单 [4955]
    4. 关于举办NOIP2006模拟赛的通告 [4106]
    5. Turbo Pascal各语句运行速... [3594]
    6. Turbo王者归来新Delphi免费... [3181]
    7. IOI2006我国4名选手全部获得金... [2945]
    8. 关于APIO2007与IOI2007... [2763]
    9. noip倒计时 by 枯叶蝴蝶 [2683]
    10. 朱泽园:思想上的金牌更重要 [2168]
    快速排序
    折半查找
     

    关于本站 | 合作伙伴 | 联系方式
    大榕树 版权所有 ©1999-2006 www.myDrs.org 闽ICP备05000721号