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

大神部落 网站建设百度推广登录平台官网

大神部落 网站建设,百度推广登录平台官网,wordpress域名更换,医疗器械商标Python 堆(Headp) Python中堆是一种基于二叉树存储的数据结构。 主要应用场景: 对一个序列数据的操作基于排序的操作场景,例如序列数据基于最大值最小值进行的操作。 堆的数据结构: Python 中堆是一颗平衡二叉树&am…

Python 堆(Headp)

Python中堆是一种基于二叉树存储的数据结构。

主要应用场景:

  对一个序列数据的操作基于排序的操作场景,例如序列数据基于最大值最小值进行的操作。

堆的数据结构:

  Python 中堆是一颗平衡二叉树(关于二叉树参考数据结构相关知识),且基于小堆进行存储。

  何为小堆,简单的说就是根节点永远不大于子节点的一种存储树,如下所示:

为何会形成图示的二叉树,这跟二叉树的存储及翻转规则有关,比较复杂,如果感兴趣,可查阅数据结构相关知识。

 特性:

  (1)堆的数据要基于链表(List)进行操作(堆中的数据是基于链表进行操作)。

  (2)堆直接基于链表操作,不再开辟新的存储空间。

  (3)堆头永远都是最小的值。

  (4)堆的检索是根据中序遍历方式:根节点 --> 左节点 -->右节点

常用方法:

 1 import heapq2 3 # (1)创建一个空堆,并加入数据4 heap = []5 for item in [2, 3, 1, 4]:6     heapq.heappush(heap, item)7 print heap     # 输出 [1, 3, 2, 4]8 9 # (2)根据链表构建一个堆 --> heapify
10 l = [2, 3, 1, 4]
11 heapq.heapify(l)
12 print l        # 输出 [1, 3, 2, 4]
13 
14 # (2)向堆中追加元素 -->heappush
15 heapq.heappush(l, -10)
16 print l        # 输出 [-10, 1, 2, 4, 3]
17 
18 # (3) 弹出堆头(返回堆头之后堆再进行翻转,堆头保持最小值) -->heappop
19 print heapq.heappop(l)      # 输出 -10
20 print l                     # 输出 [1, 3, 2, 4]
21 print heapq.heappop(l)      # 输出 1
22 print l                     # 输出 [2, 3, 4]
23 
24 # (4) 替换第一个元素,并构建堆 --> heapreplace
25 l = [2, 3, 1, 4]
26 print heapq.heapreplace(l, 100)     # 输出 2
27 print l                             # 输出 [1, 3, 100, 4]
28 
29 # (5)合并多个链表 --> merge
30 l = [1, 3, 2]
31 l2 = [5, 2, 3]
32 l3 = [9, 2, 3, 1]
33 print list(heapq.merge(l, l2, l3))  # 输出 [1, 3, 2, 5, 2, 3, 9, 2, 3, 1]
34 
35 # (6)多路归并 --> merge
36 #  对每一个链表进行排序,再对排序后的列表进行合并
37 print list(heapq.merge(sorted(l), sorted(l2), sorted(l3)))
38 
39 # (7)返回最大的元素 --> nlargest
40 l = [2, 3, 1, 4]
41 print heapq.nlargest(2, l)     # 输出 [4, 3]
42 
43 # (8)返回最小的元素 --> nsmallest
44 l = [2, 3, 1, 4]
45 print heapq.nsmallest(2, l)     # 输出 [1, 2]
46 
47 # (9)向堆中追加一个数据,再弹出堆头(弹出后堆不会发生翻转) --> heappushpop
48 l = [2, 3, 1, 4]
49 print heapq.heappushpop(l, -10)     # 输出 -10
50 print l                             # 输出 [2, 3, 1, 4]    
http://www.yayakq.cn/news/46923/

相关文章:

  • 模板网站设计报价做网站现在什么尺寸合适
  • 专业邯郸做网站需要网站建设的是哪一类人
  • dedecms小说网站模板网站开发专业能力
  • 网站开发和合同范本淄博网站建设好的公司
  • 无锡响应式网站建设部考试中心网站
  • 基金会网站开发方案莱芜网站优化怎么做
  • 淄博网站设计丨致信网络河津网站建设网站建设
  • 免费做网站哪里有设置WordPress文章图片
  • 如何查看网站有没有收录网站源代码生成网站
  • 装修网站系统html编辑器汉化版
  • 自己怎么做wap网站金融投资网站 php源码
  • 国外好的网站空间承德建设企业网站
  • 用自己电脑配置服务器做网站怎么在网站上做签到
  • 做网站能赚钱么百度一下京东
  • 网页制作与网站建设江西南京网站设计收费标准
  • 投诉举报网站 建设方案贵州建网站的公司
  • 肇庆网站快速排名提升百度网站模板免费下载
  • 怎么做跟P站一样的网站广东省广州市番禺区南村镇
  • 查询网站服务器类型公司做网站的费用属于什么费用
  • 广州找公司建网站代理网店
  • 国外做自动化网站免费下载的app
  • 个人做网站和百家号赚钱网站制作公司多少费用
  • 网站建设费算不算固定资产深圳哪里有做网站的
  • wordpress建站服务器选择郑州seo外包收费标准
  • 忘记网站后台密码网站不足之处
  • 建设工程招标网站温岭网站建设公司
  • 全国购网站建设网页设计模板图片中文
  • 做网站服务器系统浙江中立建设有限公司网站
  • 网站运营 广告wordpress绝对域名更改
  • 波音网站开发网页视频怎么下载到u盘