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

wordpress首页排版错误郑州seo竞价

wordpress首页排版错误,郑州seo竞价,首钢水钢赛德建设有限公司网站,网上哪个购物平台最值得信赖文章目录 堆排序二叉树堆堆排序的过程:代码实现python中的heapq模块 堆排序 二叉树 关于二叉树的操作,其实核心就是 父节点找子节点,子节点找父节点 如果要将二叉树存储到队列中,就需要找出 父子节点之间的规律: 父…

文章目录

      • 堆排序
        • 二叉树
        • 堆排序的过程:
        • 代码实现
        • python中的heapq模块

堆排序

二叉树

关于二叉树的操作,其实核心就是 父节点找子节点,子节点找父节点

如果要将二叉树存储到队列中,就需要找出 父子节点之间的规律:

  • 父找子: 2i+1(父与左) ,2i+2(父与右)
  • 子找父:(i-1)//2

在这里插入图片描述

完全二叉树

在这里插入图片描述

在这里插入图片描述

构造堆:从最后一个非叶子节点开始调整

堆排序的过程:

在这里插入图片描述

代码实现
"""
堆排序
""""""
时间复杂度 :               O(N*logN)
每次调整的时候:要么走左边要么走右边,每次只会走一个树的高度(logN)
"""def sift(li, low, high):"""调整函数,无论是构建堆还是移动堆都需要这个调整函数:param low: 根节点:param high: 堆最后一个元素的位置:return:""""""1. 先把根节点拿出来2. 比较左右节点大小,选择替换3. 将拿出来的根节点放到合适位置"""i = low  # i最开始指向根节点j = 2 * i + 1  # j开始是左孩子tmp = li[low]  # 把堆顶存起来while j <= high:  # 只要j位置有数if j + 1 <= high and li[j + 1] > li[j]:  # 如果右孩子有并且比较大j = j + 1  # j指向右孩子if li[j] > tmp:li[i] = li[j]i = j  # 往下看一层j = 2 * i + 1else:  # tmp更大,把tmp放到i的位置上li[i] = tmp  # 把tmp放到某一级领导位置上breakelse:li[i] = tmp  # 把tmp放到叶子节点上def heap_sort(li):"""1. 构建大根堆2. 调整堆为完全二叉树3."""n = len(li)for i in range((n - 1 - 1) // 2, -1, -1):"""i: 构建大根堆的时候调整部分跟的下标(构建堆的过程是从最后一个非叶子节点开始的)建堆过程(构建一个大根堆)"""sift(li, i, n - 1)for i in range(n - 1, -1, -1):# i永远指向堆的最后一个元素,堆空间每次减一给已经排好位置的腾出空间li[0], li[i] = li[i], li[0]  # 把最大的元素放到原来最后一位sift(li, 0, i - 1)  # 将堆空间每次减一,排序li = [i for i in range(100)]
import randomrandom.shuffle(li)
print(li)heap_sort(li)
print(li)
python中的heapq模块

python有一个内置的推排序模块,(在构建堆的时候,构建的是小根堆)

import random
import heapqli = [random.randint(1, 101) for i in range(10)]
print(li)
heapq.heapify(li)  # 建堆(小根堆)
for i in range(len(li)):tmp = heapq.heappop(li)  # 弹出一个最小元素

若有错误与不足请指出,关注DPT一起进步吧!!!

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

相关文章:

  • 建筑工程网是什么网站sem是什么意思?
  • 哪里可以做产品购物网站兰州网络推广优化服务
  • 怎么自己搭建小程序杭州网站优化公司哪家好
  • 微信投票网站制作提高工作效率整改措施
  • 乌鲁木齐制作网站站长统计app最新版本2023
  • 仙桃住房和城乡建设部网站付费推广
  • 新手怎么建立网站廊坊网站建设优化
  • 成都专业网站设计免费咨询怎样下载优化大师
  • 莱芜 网站必应搜索国际版
  • 网站做海外的防护软文的目的是什么
  • 乌鲁木齐网站建设深圳营销推广公司
  • 专业医疗网站建设营销和销售的区别在哪里
  • 自建网站和第三方平台的区别网页设计与制作个人网站模板
  • 如何在百度能搜索到公司网站班级优化大师app
  • 手机微官网和pc端网站怎么做必应搜索引擎
  • 个人做啥网站流量大seo技术分享免费咨询
  • 怎么做网站的点击率aso优化怎么做
  • 网站源码html福州网站建设
  • 石家庄制作网站的公司公司网站如何建设
  • 做html网站模板下载地址抚州网络推广
  • 可以写代码的网站有哪些问题成都网站建设软件
  • 黔江做网站关键词怎么提取
  • 北京营销网站建设短视频营销方式有哪些
  • 做网站资源知乎推广宣传方式有哪些
  • mvc 做网站电商网站大全
  • 网站宣传的优点网络营销推广策划的步骤是什么
  • 利辛做网站seo页面排名优化
  • 网站建设主机个人网页怎么做
  • 在百度怎么建立自己的网站吗做网站需要哪些技术
  • 白酒营销网站百度手机助手下载免费安装