我是靠谱客的博主 安详豌豆,最近开发中收集的这篇文章主要介绍list 查找_Python 算法 01--二分查找猜数游戏二分查找,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

0304796c27d1809bd4809337dab085e8.gif
6a7c6c6d823370a427e3383286b92daa.png

猜数游戏

在程序中预设一个 0-9 之间的整数,让用户通过键盘输入所猜的数,

如果大于预设的数,显示 “遗憾,太大了”;小于预设的数,显示 “遗憾,太小了”

如此循环,直至猜中该数,显示 “预测 N 次,你猜中了!”,其中 N 是用户输入数字的次数

1、Python 分析

● “预设一个 0-9 之间的整数” 可以使用 random 库中的 randint 函数

注意:randint (a,b) 区间是包含 a 和 b 的,而 range 函数左闭右合

● 用户键盘输入数字,使用 eval(input())

● 在确定循环次数时,我们用 for 循环,在不确定的时候用 while 循环

● 显示 “预测 N 次,你猜中了!”, 其中 N 可以使用 format 函数格式化

2、Python 代码

7ee2ce40b41d00553c8605aa95be82cd.png

3、策略

● 简单查找:从 1 开始依次往上猜

每次猜测只能排除一个数字,如果数字是 100,那从 1 - 100 需要猜 100 次

● 二分查找:每次猜测中间的数字

在未猜测正确前,每次猜测都将余下的数字排除一半。

d5c312e5da4ffdbc4c68f398f5963c7e.png

二分查找

d0d34098f13907543ec72b522e353403.png

数组list

● low 和 high 表示数组 list 的开始和结束

low = 0 # 数组开始

high = len(list) - 1 # 数组结束

● 只要范围没有缩小到只包含一个元素,就检查中间的元素

● 中间元素

mid = (low + high) // 2

如果 low + high 不是偶数,Python中// 向下取整


● Python 二分查找代码

ed3318534b1eb0d65774d49b7eeb0c33.png

● 二分查找的时间复杂度

d0ea986371d72adf9bce4bfffe03b60b.png

当第 K 次查找到元素,N/(2^K) >= 1

我们计算时间复杂度是按照[最坏的情况]进行计算

0f88883fef1d465578ca4a0949644bc0.png

所以二分查找的时间复杂度是log N (默认 log 的底数是 2)

注意:仅当列表是有序的时候,二分查找才管用


>>>Python算法 00--时间复杂度和空间复杂度

最后

以上就是安详豌豆为你收集整理的list 查找_Python 算法 01--二分查找猜数游戏二分查找的全部内容,希望文章能够帮你解决list 查找_Python 算法 01--二分查找猜数游戏二分查找所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部