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

美容行业培训网站建设上海百度推广优化

美容行业培训网站建设,上海百度推广优化,做网站容易还是app,海南找人做网站目录 1.顺序结构 2.示意图 ​编辑 从物理结构还原为逻辑结构的方法 3.父子节点编号的规律 4.顺序存储的前提条件 5.堆的简介 堆的定义 堆的两个重要性质 小根堆和大根堆 6.堆的插入 7.堆的实现及操作堆的函数 堆的结构体定义 堆初始化函数HeapInit 堆插入元素函…

目录

1.顺序结构

2.示意图

 ​编辑

从物理结构还原为逻辑结构的方法

3.父子节点编号的规律

4.顺序存储的前提条件

5.堆的简介

堆的定义

堆的两个重要性质

小根堆和大根堆 

6.堆的插入

7.堆的实现及操作堆的函数

堆的结构体定义

堆初始化函数HeapInit

堆插入元素函数HeapPush

堆向上调整函数AdjustUp

写法1

写法2

写法3

提问

向上调整的前提

测试堆插入函数


1.顺序结构

存储二叉树的两种结构:一种顺序结构,一种链式结构本文讲顺序结构


2.示意图

 4311a3c884de4d0caec5b45ef6aa9c66.png

上方图中的数字0~6代表各个节点的编号 

逻辑结构:方便人理解的结构 物理结构:实实在在存储的结构

可见顺序结构的底层是用数组(连续)存储的

从物理结构还原为逻辑结构的方法

对于满二叉树而言,

第一层有一个节点,第二层有两个节点,第一层有四个节点......

则可按层拆分

4f110e1b52564653809e45ad5700440e.png

再组合

aac1aff2adc14578a3eb1be99060ba31.png

加上线

68aacacb93554bda9e40b9e6ea2aa5ee.png

 对于完全二叉树而言,做法和上述类似,不再赘述

3.父子节点编号的规律

比如求F的父节点,如果画图则太慢,其实可以看出规律

F编号为5,其父节点C编号为2;E编号为4,其父节点B编号为1;

发现eq?%5B%5Cfrac%7B5-1%7D%7B2%7D%5D%3D2%2C%5B%5Cfrac%7B4-1%7D%7B2%7D%5D%3D%5B1.5%5D%3D1(注:eq?%5Bx%5D为高斯函数,又称向下取整函数)

★★★求父节点b编号的公式:eq?%5B%5Cfrac%7Bchild-1%7D%7B2%7D%5D%3Dfather

在C语言中为father = (child-1)/2;father获得表达式的商

如果给出父节点的编号,求左孩子和右孩子的编号

父节点C编号为2,则左孩子F的编号为2*2+1,则右孩子G的编号为2*2+2

★★★求孩子节点编号的公式:左孩子:eq?2*father+1  右孩子:eq?2*father+2

4.顺序存储的前提条件

结论:完全二叉树(含满二叉树)适合用顺序存储

25f932f64b0c4f89a726508dbdac504f.png

如果非完全二叉树,存储会浪费空间

5.堆的简介

堆的定义

如果有一个关键码的集合eq?K%20%3D%20%5C%7B%20k_0%2Ck_1%2Ck_2%2C...%2Ck_%7Bn-1%7D%5C%7D,把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中,并满足:eq?K_i%20%3C%3D%20K_%7B2*i+1%7Deq?K_i%3C%3D%20K_%7B2*i+2%7D%20%28K_i%20%3E%3D%20K_%7B2*i+1%7D%29eq?K_i%20%3E%3D%20K_%7B2*i+2%7D(i=0,1,2,3,..,n)则称为小堆(或大堆)

堆的两个重要性质

  • 堆中某个结点的值总是不大于或不小于其父结点的值;

  • 总是一棵完全二叉树

小根堆和大根堆 

小根堆:树中所有的父节点的值都小于或等于孩子节点的值

大根堆:树中所有的父节点的值都大于或等于孩子节点的值

如果树中所有的父节点的值都等于孩子节点的值,则既为小根堆又为大根堆

注:等定义中并没有规定左孩子和右节点的值的大小关系,因此堆不一定有序

6.堆的插入

由堆的简介可知:堆是一个完全二叉树,因此可以用顺序结构实现

以下方大根堆为例

5516201b19fc4ff4ba832151b1735e7f.jpeg

现要尾插数字20,由存储结构可以看出:空间不够,要扩容

586ea01b4e95478fadf61f4dbb53bc8f.jpeg

插入20前,找其父节点(eq?%5B%5Cfrac%7Bchild-1%7D%7B2%7D%5D%3Dfather),发现后者值为30,可以插入,仍然满足大根堆的性质 

再尾插入60

a761c72718674ece9995f70e1cfc4af1.png

发现不满足大根堆的性质,需要一次调整

4a5e53f5f43649b1a5af1733922837dd.png

发现调整后仍然不满足大根堆的性质(56<60),需要再一次调整 

36899090ed21424586fb62e5227a50d4.png

发现调整后满足大根堆的性质(56<60<70),结束

上述的调整起名为向上调整,最多调整h(二叉树的高度)次

7.堆的实现及操作堆的函数

以大根堆为例

堆的结构体定义

可以用结构体来定义堆,由于堆的底层是用数组存储的,因此三个成员变量:数据域,大小size,容量capacity

写入头文件中

typedef int HPDataType;
typedef struct Heap
{HPDataType* a;int size;int capacity;
}HP;

堆初始化函数HeapInit

要想使用堆必须先初始化堆(malloc,对size和capacity初始化值)

void HeapInit(HP* php)
{assert(php);php->a = (HPDataType*)malloc(sizeof(HPDataType) * 4);if (php->a == NULL){perror("malloc");return;}php->size = 0;php->capacity = 4;
}

php->capacity跟随malloc函数开辟空间的大小

堆插入元素函数HeapPush

插入前先判断空间是否充足,不够则relloc原来的2倍.之后调用向上调整函数进行插入

void HeapPush(HP* php, HPDataType x)
{assert(php);if (php->size == php->capacity){HPDataType* tmp = (HPDataType*)realloc(php->a, sizeof(HPDataType) * php->capacity * 2);if (tmp == NULL){perror("realloc");return;}php->a = tmp;php->capacity *= 2;}php->a[php->size] = x;//插入至数组的最后一个元素的下一个位置(size)php->size++;//数组大小+1//调用向上调整函数AdjustUp(php->a,php->size-1);
}

注意到AdjustUp传的第二个参数是php->size-1

堆向上调整函数AdjustUp

如果a[parent] < a[child],则进行交换,之后调整parent和child的值,以便于下一次调整

写法1

void Swap(HPDataType* p1, HPDataType* p2)
{HPDataType tmp = *p1;*p1 = *p2;*p2 = tmp;
}void AdjustUp(HPDataType* a, int child)
{int parent = (child - 1) / 2;while (a[parent] < a[child]){Swap(&a[parent], &a[child]);//调整parent和child的值child = parent;parent = (parent - 1) / 2;}
}

写法2

void AdjustUp(HPDataType* a, int child)
{int parent = (child - 1) / 2;while (parent>=0){if (a[child] > a[parent]){Swap(&a[parent], &a[child]);child = parent;parent = (parent - 1) / 2;}else{break;}}
}

写法3

void AdjustUp(HPDataType* a, int child)
{int parent = (child - 1) / 2;while (child>0){if (a[child] > a[parent]){Swap(&a[parent], &a[child]);child = parent;parent = (parent - 1) / 2;}else{break;}}
}

提问

已知这几种写法都能成功运行,哪个写法存在不规范的地方?

答:从特殊情况考虑问题,写法2:

当parent==0时,进入循环,若child==1,if判断成立,交换值后,child==0,parent==-1/2==0(取商)

while(parent>=0)条件仍然成立,但不满足if (a[child] > a[parent]),因此break

不规范的地方:child==parent==0就没有必要再次进入循环,建议改成while (child>0)(写法3)

向上调整的前提

除了child位置,前面的数据结构构成堆

测试堆插入函数

main.c手动写入插入一些随机值,以下代码,下断点至return 0;

#include "Heap.h"
int main()
{HP hp;HeapInit(&hp);HeapPush(&hp, 1);HeapPush(&hp, 3);HeapPush(&hp, 0);HeapPush(&hp, 5);HeapPush(&hp, 8);HeapPush(&hp, 12);HeapPush(&hp, 2);HeapPush(&hp, 5);HeapPush(&hp, 30);HeapPush(&hp, 50);return 0;}

打开监视窗口查看

ed16365c491d4a4eb9b111b7b3f5ec30.png

画图后发现符合大根堆的性质

7ab07688e63a4274bcb0527f7b168b07.png

http://www.mmbaike.com/news/74720.html

相关文章:

  • 网站建设公司推我的百度账号登录
  • wordpress主题开发框架360优化大师下载安装
  • 怎么做网站的一个横向列表b站推广链接
  • 漯河做网站的公司宝鸡seo排名
  • 网站与个人网站武汉网站推广排名
  • 北京网站优化软件公司优化建站seo门户
  • 哪个网站做任务能赚钱谷歌搜索引擎入口2021
  • 旅行社网站建设昆明网络推广公司排名
  • 电子商务网站的建设 论文太原网站关键词排名
  • 做网站和网页有区别吗如何模板建站
  • 设计师做网站的流程google官网下载安装
  • 简单网页制作模板源代码哈尔滨seo和网络推广
  • 网页游戏平台制作seo案例分析100例
  • 做旅游平台网站找哪家好优化大师win10
  • 深圳网站制作公司建设徐州百度快照优化
  • wordpress微信登录页面搜索引擎优化课程总结
  • php做网站后台教程百度seo网站
  • 怎样建设一个内部网站线上it培训机构
  • 北京做冷冻牛羊肉的网站百度信息流怎么收费
  • 自己提供域名做网站软文广告营销
  • wordpress 登录注册网站怎么优化排名的方法
  • 营销型集团网站建设搜索引擎排名优化方法
  • 上海做网站建设的公司排名app营销策略
  • 全国十大网络公司aso优化怎么做
  • 海口旅游类网站建设网站平台都有哪些
  • wordpress主题里文章添加留言板对网站提出的优化建议
  • 深圳外贸网站优化哪家好逆冬seo
  • 做家教在哪个网站找论坛软文案例
  • 南宁上林网站建设网络优化的流程
  • 购物网站开发 英文文献免费入驻的跨境电商平台