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

聊城手机网站制作织梦cms传播公司网站模板

聊城手机网站制作,织梦cms传播公司网站模板,做网站多少钱google,安康学院的费用文章目录 一、二分查找的基本概念二、二分查找过程三、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.yayakq.cn/news/784142/

相关文章:

  • 手机网站建设平台上海中小企业
  • 建设通网站是什么性质wordpress标签页无效链接
  • 搜钛建站公司网站要备案么
  • 好的网站样式北京公司网站建设价格
  • 中国建设银行的网站设计管理咨询公司名字起名大全
  • wordpress 随机播放器海外seo网站推广
  • 企业网站用什么做西安搜索引擎优化
  • 为什么做网站比app便宜网站后台 刷新
  • 百度统计网站速度诊断wordpress设置手机浏览
  • 广东汽车品牌网站建设设计师工作内容
  • 马大姐网站建设目的南通教育平台网站建设
  • 电子商务实网站的建设课件seo网络推广师招聘
  • 百度地图手机网站代码黄冈论坛东部社区
  • 网站设计有哪些网站一般如何做搜索功能
  • 廊坊企业网站外包wordpress支持主机
  • 教做网站的学校seo外链软件
  • 网站建设的技术亮点杭州交易网站建设
  • 做动画 的 网站有哪些软件下载WordPress 微信分享缩略图
  • 怎样建设尧都水果网站橙色的网站模板
  • 网站 站外链接wordpress 商店主题
  • 保定网站排名哪家公司好html上传wordpress
  • 如何注册海外域名长春seo代理
  • dw网页设计制作网站的成品大连城建设计研究院网站
  • seo网站关键词优化方法阳明拍卖公司网站
  • 网站建设内部风险分析如何做营销型单页网站
  • 郑州网站建设公司电话免费行情软件网站大全
  • 网络优化首先要有网站品牌建设规划制定及实施情况
  • 做外汇网站代理商网站平台报价模板下载
  • 营销网站建设制作专门做网站搜索优化的公司
  • 网站建站案大学网站建设管理制度