数据结构之二叉树与堆以及力扣刷题函数扩展

这篇具有很好参考价值的文章主要介绍了数据结构之二叉树与堆以及力扣刷题函数扩展。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

个人主页:点我进入主页

专栏分类:C语言初阶      C语言程序设计————KTV       C语言小游戏     C语言进阶

C语言刷题       数据结构初阶

欢迎大家点赞,评论,收藏。

一起努力

目录

1.前言

2.树

2.1概念

 2.2树的相关概念

3.堆

3.1堆的概念

3.2小堆函数实现

4.力扣刷题函数

5.总结


1.前言

        在前面我们学习了关于顺序表,链表,栈,队列的存储方式。今天我将给大家带来关于树的一些内容以及堆的部分内容,详细包括树的定义,树相关的概念,二叉树和满二叉树的概念,树代码的实现会在后面的内容,大堆和小堆的代码实现。今天的内容相较于前面会有一点难以理解,希望大家可以认真学习,当然还有几个力扣刷题的函数扩展,其中的内容就绝对会让你感到其中的乐趣。

2.树

2.1概念

        树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。有一个特殊的结点,称为根结点,根节点没有前驱结点除根节点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、……、Tm,其中每一个集合Ti(1<= i<= m)又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继因此,树是递归定义的。

下面我给出关于树的图:

数据结构之二叉树与堆以及力扣刷题函数扩展,数据结构初阶,数据结构

 2.2树的相关概念

节点的度:一个节点含有的子树的个数称为该节点的度; 如上图:A的为6
叶节点或终端节点:度为0的节点称为叶节点; 如上图:B、C、H、I...等节点为叶节点
非终端节点或分支节点:度不为0的节点; 如上图:D、E、F、G...等节点为分支节点
双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点; 如上图:A是B的父节点
孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点; 如上图:B是A的孩子节点
兄弟节点:具有相同父节点的节点互称为兄弟节点; 如上图:B、C是兄弟节点
树的度:一棵树中,最大的节点的度称为树的度; 如上图:树的度为6
节点的层次:从根开始定义起,根为第1层,根的子节点为第2层,以此类推;
树的高度或深度:树中节点的最大层次; 如上图:树的高度为4
堂兄弟节点:双亲在同一层的节点互为堂兄弟;如上图:H、I互为兄弟节点
节点的祖先:从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先
子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙
森林:由m(m>0)棵互不相交的树的集合称为森林。

3.堆

3.1堆的概念

        如果有一个关键码的集合K = { , , ,…, },把它的所有元素按完全二叉树的顺序存储方式存储 在一个一维数组中,并满足: <= 且 <= ( >= 且 >= ) i = 0,1, 2…,则称为小堆(或大堆)。将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。堆我们分为大堆个小堆,大堆是父节点永远大于子节点,小堆是父节点永远小于子节点。堆的图我们认为堆是如下的样子:

数据结构之二叉树与堆以及力扣刷题函数扩展,数据结构初阶,数据结构

事实上我们是顺序表的形式存储的,我们知道堆是一颗完全二叉树,我们将树的每个节点用数字进行标记,如下:

数据结构之二叉树与堆以及力扣刷题函数扩展,数据结构初阶,数据结构

我们不难得出我们知道父节点的编号为n,左孩子的编号为2n+1,右孩子的编号为2n+2,假设左孩子的标号为n那么父节点的编号为(n-1)/2,我们设右孩子的节点为n那么父节点的编号为(n-1)/2,那我们很容易得到孩子节点编号为n父节点的编号为(n-1)/2,根据这一特点我们就可以利用顺序表进行存储,这样也能更好的找到父节点和孩子节点的位置,接下来我们以实现小堆为例子来展示一下大堆和小堆的实现(大堆和小堆的差距只有向上调整的部分符号不同,其余基本一致)。

3.2小堆函数实现

#define _CRT_SECURE_NO_WARNINGS 1
#include"Heap.h"
void Swap(MyHeapData* num1, MyHeapData* num2)
{
	MyHeapData temp = *num1;
	*num1 = *num2;
	*num2 = temp;
}
void AdJustUp(MyHeapData* arr, int size)
{
	assert(arr);
	int child = size - 1, parent = (child - 1) / 2;
	while (child > 0)
	{
		if (arr[child] < arr[parent])
		{
			Swap(&arr[child], &arr[parent]);
			child = parent;
			parent = (child - 1) / 2;
		}
		else
			break;
	}
}
void HeapInit(Heap* php)
{
	assert(php);
	php->data = (MyHeapData*)malloc(sizeof(MyHeapData));
	php->size = 0;
	php->capacity = 0;
}
void HeapDestory(Heap* php)
{
	assert(php);
	free(php->data);
	php->data = NULL;
}
void HeapPush(Heap* php, MyHeapData x)
{
	if (php->size == php->capacity)
	{
		int newcapacity = php->capacity + 2;
		MyHeapData* arr = (MyHeapData*)realloc(php->data, newcapacity * sizeof(MyHeapData));
		if (arr == NULL)
		{
			perror("realloc fail");
			return;
		}
		php->data = arr;
		php->capacity = newcapacity;
	}
	php->data[php->size++] = x;
	AdJustUp(php->data, php->size);
}
void print(Heap* php)
{
	for (int i = 0; i < php->size; i++)
		printf("%d ", php->data[i]);
}
void HeapPop(Heap* php)
{
	assert(php);
	if (!HeapEmpty(php))
	{
		Swap(&php->data[0], &php->data[php->size - 1]);
		php->size--;
		AdJustDown(php->data, php->size);
	}
}
void AdJustDown(MyHeapData* arr, int size)
{
	assert(arr);
	int parent = 0, child = parent * 2 + 1;
	while (child<size)
	{
		if (child + 1 < size && arr[child] > arr[child + 1])
		{
			child++;
		}
		Swap(&arr[parent], &arr[child]);
		parent = child;
		child = parent * 2 + 1;
	}
}
bool HeapEmpty(Heap* php)
{
	assert(php);
	return php->size == 0;
}
void text()
{
	Heap ph;
	HeapInit(&ph);
	HeapPush(&ph, 7);
	HeapPush(&ph, 6);
	HeapPush(&ph, 4);
	HeapPush(&ph, 5);
	HeapPush(&ph, 1);
	HeapPush(&ph, 1);
	HeapPush(&ph, 3);
	print(&ph);
	printf("\n");
	HeapPop(&ph);
	print(&ph);
	printf("\n");
	HeapPop(&ph);
	print(&ph);
	HeapDestory(&ph);
}

到这里我们的小堆就实现完了。

4.力扣刷题函数

        函数为sscanf函数和sprintf函数,其中sscanf函数是将任意类型数据储存在字符串中,spintf函数是将字符串数据输入到新的变量中,他们重新定义了输入输出流,我们看下面代码来感受一下:

#include<stdio.h>
int main()
{
	int a = 10;
	char arr[] = "abcd";
	double f = 1.99;
	char brr[100];
	sprintf(brr, "%d %s %f", a, arr, f);
	printf("%s\n", brr);
	a = 0;
	double b = 0.0;
	sscanf(brr, "%d %s %f", &a, &arr, &b);
	printf("%d %s %f", a, arr, f);
	return 0;
}

运行结果如下:

数据结构之二叉树与堆以及力扣刷题函数扩展,数据结构初阶,数据结构

5.总结

        今天的内容到这里就结束了,非常感谢大家的观看,希望大家可一学到很多东西,尤其是堆的向下调整和向上调整这两个函数。文章来源地址https://www.toymoban.com/news/detail-760762.html

到了这里,关于数据结构之二叉树与堆以及力扣刷题函数扩展的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [数据结构] 树与二叉树

    树是由 (n(n geq 0)) 个节点组成的有限集。当 (n = 0) 时,称为空树。 任意一棵非空树应满足以下两点: (1)有且仅有一个特定的称为根的节点; (2)当 (n 1) 时,其余节点可分为 (m(m0)) 个互不相交的有限集 (T_1, T_2, dots, T_m) ,其中每个集合本身又是一棵树,称为根的

    2024年03月09日
    浏览(32)
  • 数据结构_树与二叉树

    目录 1. 树的基本概念 1.1 树的定义 1.2 基本术语 1.3 树的性质 1.4 相关练习 2. 二叉树的概念 2.1 二叉树的概念及其主要特性 2.2 二叉树的存储结构 2.2.1 顺序存储结构 2.2.2 链式存储结构 2.3 相关练习 3. 二叉树的遍历和线索二叉树 3.1 二叉树的遍历 3.1.1 先序遍历 3.1.2 中序遍历 3.1

    2024年02月04日
    浏览(33)
  • 【数据结构】树与二叉树(中)

    目录 前言: 一、顺序存储结构: 二、堆: 1.堆的性质: 2.堆的性质: 3.堆的实现: Ⅰ.堆的初始化:  Ⅱ.堆的插入(含向上调整):  Ⅲ.堆的删除(含向下调整算法): Ⅳ.取堆顶的数据: Ⅴ.堆中的数据个数: Ⅵ.堆的判空:  Ⅶ.堆的销毁: 总结:         上篇文章中,

    2024年02月16日
    浏览(33)
  • 数据结构:图文详解 树与二叉树(树与二叉树的概念和性质,存储,遍历)

    目录 一.树的概念 二.树中重要的概念 三.二叉树的概念 满二叉树 完全二叉树 四.二叉树的性质 五.二叉树的存储 六.二叉树的遍历 前序遍历 中序遍历  后序遍历  树是一种 非线性数据结构 ,它由节点和边组成。树的每个节点可以有零个或多个子节点,其中一个节点被指定为

    2024年02月04日
    浏览(40)
  • 数据结构与算法——树与二叉树

    😊各位小伙伴久等了,本专栏新文章出炉了!!! 我又回来啦,接下来的时间里,我会持续把数据结构与算法专栏更新完。 👉树型结构👈 是一类重要的 ✍非线性数据结构 ,其中以树和二叉树最为常用,直观来看,树是以分支关系定义的层次结构。树型结构在客观世界中

    2024年02月11日
    浏览(31)
  • 【数据结构与算法】树与二叉树

    除了之前我们讲的栈、队列、链表等线性结构,数据结构中还有着一对多的 非线性结构 ——— 树 。 树是有 n 个结点组成的有限集,当n=0时为空树,在任意一颗非空树中,有且仅有一个 特定的根结点 ;当n1时,其余结点又可以分为一棵树,称为根的 子树 。 如下图所示: A为

    2023年04月09日
    浏览(34)
  • 【数据结构】树与二叉树(十三):递归复制二叉树(算法CopyTree)

      二叉树是一种常见的树状数据结构,它由结点的有限集合组成。一个二叉树要么是 空集 ,被称为 空二叉树 ,要么由一个根结点和两棵不相交的子树组成,分别称为 左子树 和 右子树 。每个结点最多有两个子结点,分别称为左子结点和右子结点。 引理5.1:二叉树中层数

    2024年02月01日
    浏览(27)
  • 数据结构之二叉树

    前言:我们前面已经学习了数据结构的栈和队列,今天我们就来学习一下数据结构中的二叉树,那么作为二叉树我们就得先了解树的一些概念,还有二叉树一些特点。 树是一种非线性的数据结构,它是由n(n=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因 为它

    2024年02月05日
    浏览(31)
  • 数据结构之二叉树和平衡二叉树

    1、二叉树: 2、平衡二叉树:

    2024年04月17日
    浏览(30)
  • 11. 数据结构之二叉树

    上一节,简单概述了树这种数据结构,以及树结构向下,具有某些一些特征的树,比如二叉树,B树,B+树,堆等。其中,二叉树是一个很重要的模块。也是在一些技术面试中,可能会问到的问题。本节,我们就二叉树,做详细介绍。 二叉树是一个 逻辑结构 , 底层可以用数组

    2024年02月07日
    浏览(25)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包