网站大量收购闲置独家精品文档,联系QQ:2885784924

奥数编程课程二分查找.doc

奥数编程课程二分查找.doc

此“教育”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

这节课我们来学习二分查找,教大家用二分查找的方法在Scratch中同样来实现程序:查找某个数是否属于斐波那契数列中,若属于,要求说出查找次数和所在的位置;最后对比二分查找和顺序查找。

二分查找定义:

???????在一个已知有序数列中找出与给定关键字相同的数。

算法流程:

1.?给定一个有序数组a,和一个要查找的关键字s;

??????????2.将a的中间项与s进行比较,如果s等于a的中间项,则查找成功;如果s比a的中间项要小,则到a的前半部分继续查找,反之,则到a的后半部分继续查找;

3.?如此反复,直到在a中找到s,或者没有元素可以继续找。

?

第一步,?生成斐波那契数列和要查找的数字

斐波那契数列的生成与上节课顺序查找中的相同。

第二步,?构造二分查找函数并调用

2.1)建立变量searchnumber,left,right,count并初始化;searchnumber用来保存输入的要查找的数;left和right分别用来定位当前数列的最左边数和最右边数的位置;count用于计算并保存查找次数;

?

2.2)建立循环直到数列全部遍历完(即LeftRight);

每循环一次,count增加1,获取当前数列中间项,并用变量middle保存;

将当前中间项(即数列的第middle项)与searchnumber进行比较,如果相等,则查找成功,并说出查找次数和所处位置;

如果当前中间项比searchnumber要小,则到当前数列的后半部分继续查找,反之,则到当前数列的前半部分继续查找;

2.3)如果全部遍历完斐波那契数列后,还没有查找到输入的数字,则查找失败!

2.4)调用顺序查找函数:将?写入到生成斐波那契数列的代码后面。

?

完整代码是:

??????????

?

举一反三

跟顺序查找一样,通过利用二分查找算法,同样可以实现

电话簿里查找电话号码

在学校学生记录中查找某学号寻找对应同学信息

火车站检票时查找身份证号码以验证某人是否是犯罪分子.

?

思考:

???????请大家思考,从原理、适用条件、查找次数等家角度对二分查找和顺序查找进行对比.

给定一个数列?{1,2,3,3,5,7,9,9,9,9,14,18}?,在该数列中用二分查找的方法查找是否存在S(S=9)?若存在,请给出S的个数及其对应的位置。(注意:要给出所有的S(S=9))

您可能关注的文档

文档评论(0)

yzs890305 + 关注
实名认证
内容提供者

计算机二级持证人

该用户很懒,什么也没介绍

领域认证该用户于2024年11月02日上传了计算机二级

1亿VIP精品文档

相关文档