二叉树

二叉树

  • 一颗树至少会有一个节点
  • 每个节点不能多于2个叶子

节点的定义:一个数据,两个指针

递归

二叉查找树

根节点的值大于其左子树中任意一个节点的值,小于其右节点中任意一节点的值

查一个值的方式正是二分查找的思想,查找所需的最大次数等同于二叉查找树的高度

二叉查找树的缺陷?

插入76543,查找的性能大打折扣,几乎变成了线性。
如何解决二叉查找树多次插入新节点而导致的不平衡呢?我们的主角红黑树应运而生了

平衡二叉树

它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树

当有新的节点要插入时,检查是否因插入后而破坏了树的平衡,如果是,则需要做旋转去改变树的结构

红黑树

  • 红黑树是一种自平衡的二叉查找树
  • 跟节点是黑色,其它节点是红色或黑色
  • 每个叶子节点(NIL)是黑色
  • 如果一个节点是红色的,则它的子节点必须是黑色的
  • 从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点
     
    红黑树有一个重要的性质,从根节点到叶子节点的最长路径不多于最短的路径的长度的两倍

当插入或删除节点的时候,红黑树的规则有可能被打破。这时候就需要作出一些调整,来继续维持我们的规则
调整有两种方法:变色和旋转,旋转分左旋转和右旋转

堆的结构

堆就是用数组实现的二叉树

最大堆:根结点的键值是所有堆结点键值中最大者,且每个结点的值都比其孩子的值大。//从大到小

最小堆:根结点的键值是所有堆结点键值中最小者,且每个结点的值都比其孩子的值小、、从小到大

堆的常用方法:

构建优先队列
支持堆排序
快速找出一个集合中的最小值(或者最大值)
在朋友面前装逼

https://www.jianshu.com/p/6b526aa481b1

堆和树的区别

1、结构上:

二叉排序树:左子树小于根节点,根节点又小于右子树。
堆(小堆):根节点小于左右子树,但是左右子树没有大小之分。

2、作用上:

从上面各自的结构上的分析可得:二叉排序树是用来做查找的,而堆是用来做排序的

堆和栈在内存中的区别是什么(解答提示:可以从数据结构方面以及实际实

https://blog.csdn.net/github_37130188/article/details/99491588

什么是深拷贝和浅拷贝

浅拷贝是一个传址,也就是把a的值赋给b的时候同时也把a的址赋给了b,当b(a)的值改变的时候,a(b)的值同时也会改变

深拷贝:深拷贝是指,拷贝对象的具体内容,二内存地址是自主分配的,拷贝结束之后俩个对象虽然存的值是一样的,但是内存地址不一样,俩个对象页互相不影响,互不干涉

二叉树的深度优先遍历和广度优先遍历的具体实现

https://blog.csdn.net/github_37130188/article/details/99490536

手写链表逆序代码
讲一下对树,B+树的理解
讲一下对图的理解
判断单链表成环与否?
链表翻转(即:翻转一个单项链表)
合并多个单有序链表(假设都是递增的)

看完就彻底懂了红黑树!红黑树的插入、删除、左旋、右旋

https://www.cnblogs.com/cangqinglang/p/12455433.html

二叉查找树(Binary Search Tree),也称有序二叉树(ordered binary tree),排序二叉树(sorted binary tree),是指一棵空树或者具有下列性质的二叉树:

  • 若任意结点的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
  • 若任意结点的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
  • 任意结点的左、右子树也分别为二叉查找树。
  • 没有键值相等的结点(no duplicate nodes)。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值