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

凡科网建设网站如何修改源代码一个公司做两个网站可以吗

凡科网建设网站如何修改源代码,一个公司做两个网站可以吗,门店设计方案,平面设计1.堆的概念 如果有⼀个集合 K {k0&#xff0c;k1&#xff0c;k2&#xff0c;...&#xff0c;k(n-1)} &#xff0c;把它的所有元素按完全二叉树的形式存储在一个一维数组中&#xff0c;并满足&#xff1a;K(i)<2*i1且K(i)<2*i2&#xff08;K(i)>2*i1且K(i)>2*i2&a…

1.堆的概念

如果有⼀个集合 K = {k0,k1,k2,...,k(n-1)} ,把它的所有元素按完全二叉树的形式存储在一个一维数组中,并满足:K(i)<=2*i+1且K(i)<=2*i+2(K(i)>=2*i+1且K(i)>=2*i+2),i=0,1,2... ,则称为小堆(或大堆),将根结点最大的堆叫做最大堆或大根堆,根结点最小的堆叫做最小堆或小根堆

例:有一组数据:10,65,70,30,15,25

                                

2.堆的实现

(1)初始化堆

(2)堆的销毁

(3)交换

(4)堆的插入

 (5)向上调整

为了构建小堆或大堆,在插入数据时,可以将插入的数据看作孩子,在满足双亲的下标>=0(孩子的下标大于0)将孩子与双亲作对比,向上调整数据

图例:

向上调整算法的时间复杂度:(为了简化使用满二叉树来证明)

则每层节点需要移动的次数为:每层结点的个数*向上移动的次数,节点总共需要移动的次数为:所有层节点需要移动的次数之和

T(h)=2^1*1+2^2*2+2^3*3+...+2^(h-2)*(h-2)+2^(h-1)*(h-1)                       ①

2*T(h)=2^2*1+2^3*2+2^4*3+...+2^(h-1)*(h-2)+2^(h)*(h-1)                       ②

①-②:-T(h)=2^1+2^2+2^3+...+2^(h-2)+2^(h-1)-2^h*(h-1)                                                                                    =2^h-2-2^h*(h-1)                                                                                                                                =2^h(2-h)-2

T(h)=2^h(h-2)+2,根据二叉树的性质:n=2^h-1,h=log2(n+1)

得F(n)=(n+1)(log2(n+1)-2)+2,故向上调整算法的时间复杂度为:O(n*log2(n))

(6)打印堆

(7)判空

 (8)堆的删除

删除堆顶数据就是将数组开头的元素和数组末尾的元素交换,将堆中size的值减一,此时堆中的结构可能被改变,不再是大堆(小堆),需要将堆顶元素向下调整

(9)向下调整

以此时的堆顶元素为双亲,在满足孩子的下标小于堆元素个数的情况下,与两个孩子作对比(如果没有右孩子,则只和左孩子做对比),不断向下调整数据

图例:

向下调整算法的时间复杂度:(为了简化使用满二叉树来证明)

则每层节点需要移动的次数为:每层结点的个数*向下移动的次数,节点总共需要移动的次数为:所有层节点需要移动的次数之和

T(h)=2^0*(h-1)+2^1*(h-2)+2^2*(h-3)+...+2^(h-3)*2+2^(h-2)*1                       ①

2*T(h)=2^1*(h-1)+2^2*(h-2)+2^3*(h-3)+...+2^(h-2)*2+2^(h-1)*1                    ②

②-①:T(h)=2^1+2^2+2^3+...+2^(h-2)+2^(h-1)+1-h                                                                                             =2^h-1-h

根据二叉树的性质:n=2^h-1,h=log2(n+1) 

T(n)=n-log2(n+1),故向下调整算法的时间复杂度为O(n)                        

(10)取堆顶元素

3.堆排序

(1)在数据结构堆中实现排序

创建数据结构堆,将数组中的元素一一插入堆中,在堆不为空的情况下,循环取堆顶放入数组中,再删除堆顶,每次取出的堆顶都是堆中的最大值或最小值,由此实现升序或降序排列

(2)利用堆的思想在数组中实现排序

通过向上调整或向下调整将数组排列成堆的结构(若要排升序,则建大堆,排降序,则建小堆),将数组开头的元素和末尾的元素交换,将此时数组开头的元素看作双亲,向下调整

堆排序算法的时间复杂度为:O(nlog2(n)),效率高于冒泡排序

http://www.dtcms.com/a/518842.html

相关文章:

  • 自助建手机网站免费一个完整的网站推广方案
  • 网站收缩栏做化工资讯的网站
  • 昆明企业网站开发公司昆山张浦做网站
  • 网站建设注意哪些内容你会回来感谢我的正能量视频
  • 网站开发 精品课程电子商务网站建设管理论文
  • 东莞教育网站建设公园网站建设
  • 企业网站asp模板重庆住房和城乡建设厅网站
  • 模板网站的缺陷乐清 网站建设
  • 商务类网站青岛网站推广公司
  • 安徽省工程建设信息官方网站网页设计颜色代码表
  • 建设网站需要些什么手续抖音电商培训
  • 网站相关知识域名解析ip138在线查询
  • c2c网站都有哪些班级网站 程序
  • 深圳公司黄页企业名录生哥seo博客
  • 网站策划方案目标公司网站邮箱怎么看接收服务器类型
  • 龙之向导外贸经理人网站以网站建设为开题报告
  • 制作网站流程深圳品牌设计公司有哪些
  • 江阴招聘网站建设学徒建站行业市场分析
  • 宁波网站设计开发网站建设运动会成绩管理系统
  • 重庆响应式网站建设公司娱乐网站设计多少行业
  • 有没有帮别人做网站备案通过后 添加网站
  • 做网站的市场细分小程序后台
  • 那个有那种网站建设招聘网站需要哪些资质
  • 针织厂家东莞网站建设做自媒体发视频用哪些网站
  • 网站主机名是什么网站建设柒金手指花总12
  • 许昌网站建设公司番禺俊才网
  • 顶尖手机网站建设微信小程序源码网站
  • 长沙旅游网站制作东莞设计展
  • 食品网站app建设方案为wordpress开发app
  • 肇庆建站模板源码长春网站优化教程