当前位置: 首页 > news >正文

2016大型注册域名网站有哪些网络推广电话

2016大型注册域名网站有哪些,网络推广电话,wordpress pwshell,如何开科技软件文章目录 一、二分查找的基本概念二、二分查找过程三、python实现二分查找的两种方式🍇递归代码实现二分查找算法🥕非递归的方式实现二分查找算法 三、拓展:二叉树反推 一、二分查找的基本概念 二分查找又称折半查找,它是一种效率…

文章目录

  • 一、二分查找的基本概念
  • 二、二分查找过程
  • 三、python实现二分查找的两种方式
    • 🍇递归代码实现二分查找算法
    • 🥕非递归的方式实现二分查找算法
  • 三、拓展:二叉树反推

一、二分查找的基本概念

二分查找又称折半查找,它是一种效率较高的查找方法

  • 原理:首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。

二、二分查找过程

查找数字: 1

在这里插入图片描述

  • 第一步: 找到中值(取整数)
  • 第二步: 要查找的数和中值比较
  • 第三步: 若小于中值则在中值前面找,若大于中值则在中值后面找,等于中值时直接返回

三、python实现二分查找的两种方式

🍇递归代码实现二分查找算法

   def binary_search(alist, item):if len(alist) == 0:return Falseelse:midpoint = len(alist)//2if alist[midpoint]==item:return Trueelse:if item<alist[midpoint]:return binary_search(alist[:midpoint],item)else:return binary_search(alist[midpoint+1:],item)testlist = [0, 1, 2, 8, 13, 17, 19, 32, 42,]print(binary_search(testlist, 3))print(binary_search(testlist, 13))

🥕非递归的方式实现二分查找算法

def binary_search(alist, item):first = 0last = len(alist)-1while first<=last:midpoint = (first + last)/2if alist[midpoint] == item:return Trueelif item < alist[midpoint]:last = midpoint-1else:first = midpoint+1return False
testlist = [0, 1, 2, 8, 13, 17, 19, 32, 42,]
print(binary_search(testlist, 3))
print(binary_search(testlist, 13))

三、拓展:二叉树反推

我们如何根据提供的三种深度排序中的两种排序,反推出来二叉树的图呢?

反推原理:先根中定边,往复树两边
举例说明,如:
先序:0 1 3 7 8 4 9 2 5 6
中序:7 3 8 1 9 4 0 5 2 6

1、先序找根,中序定两边
先序的特点是第一个元素是根,中序的特点是根两侧分别是左右子树,所以我们反推分界初始图:
在这里插入图片描述

2、两边重复步骤1
根据中序的内容,我们确定了两个子树包含的内容,那么结合先序的特点,两个范围内首先出现的数字就是第一层的节点内容
在这里插入图片描述
所以左侧子树的根节点是1,右侧子树的根节点是2

在这里插入图片描述
3、两边重复步骤1和2

找到左侧子树的根节点是1,
那么结合中序的左侧子树内容:7 3 8 1 9 4,可以确定:左侧子树包括

  • 左部分:738
  • 右部分:94

结合先序的左侧子树内容:1 3 7 8 4 9,可以确定:左侧子树的1元素的两个子节点是3和9

找到右侧子树的根节点是2

  • 结合中序的右侧子树内容:5 2 6
  • 结合先序的右侧子树内容:2 5 6

可以确定:2节点的左侧元素是5,右侧元素是6
在这里插入图片描述

4、重复步骤3
对于3结点来说:

  • 结合中序的内容:7 3 8
  • 结合先序的内容:3 7 8
    可以确定:3节点的左侧元素是7,右侧元素是8

对于9结点来说:

  • 结合中序的内容:9 4
  • 结合先序的内容:4 9

可以确定:9节点的左侧元素是4

所以最终的二叉树图是:

在这里插入图片描述

http://www.ds6.com.cn/news/41212.html

相关文章:

  • 邯郸做wap网站费用google搜索引擎入口2022
  • 市场营销策略国内外研究现状百度快速优化软件排名
  • 网站建设怎么刚刚中国突然宣布
  • 所有网站的名字大全网络营销的主要手段
  • 湖南企业建网站互联网广告销售是做什么的
  • 做企业网站怎么接活百度统计怎么使用
  • 真正免费的自学网站百度信息流广告位置
  • 平谷建站推广培训学校加盟费用
  • wordpress安装配置php5.2辽阳网站seo
  • 台州网站推广推广普通话宣传内容
  • 做网站买过域名之后百度河南代理商
  • 响应式网页设计图片南京谷歌seo
  • 站长工具怎么关掉培训心得总结怎么写
  • 北京专业网站建设公司个人建站
  • 网站建设公司的商业模式贵港seo关键词整站优化
  • 有哪些做的好的营销型网站国内建站平台有哪些
  • 工商局网站实名认证怎么做外包公司软件开发
  • 平湖模板网站建设公司精准网络营销推广
  • 网站做营销推广百度高级搜索
  • 大连做网站团队竞猜世界杯
  • 南通网站建设外包国内新闻大事20条
  • 网站建设维护与推广自己做网站如何赚钱
  • 解决方案的网站建设廊坊百度快照优化排名
  • 国内经典网站站长联盟
  • 高端的网站设计多少钱百度关键词搜索引擎
  • 十大不收费看盘软件网站seo研究中心好客站
  • behance设计网站图片百度推广关键词怎么设置好
  • 深圳网站排名怎么做潍坊seo培训
  • 我们做网站 出教材 办育心经免费个人网站平台
  • 长沙网站制作合作商seo排名工具