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

怎么做离线网站公司网站推广费用

怎么做离线网站,公司网站推广费用,青岛网站建设博采网络,网站搜索引擎友好性C二叉搜索树 1. 二叉搜索树的概念 二叉搜索树(BST,Binary Search Tree),也称为二叉排序树或二叉查找树。它与一般二叉树的区别在于:每个结点必须满足“左孩子大于自己,右孩子小于自己”的规则。在这种规则的约束下,二…

C++二叉搜索树

1. 二叉搜索树的概念

二叉搜索树BST,Binary Search Tree),也称为二叉排序树或二叉查找树。它与一般二叉树的区别在于:每个结点必须满足“左孩子大于自己,右孩子小于自己”的规则。在这种规则的约束下,二叉搜索树使用中序遍历出来的数据是一个由小到大排列的结果。

在这里插入图片描述

优点:

  1. 查找某个值最多只需要遍历高度次即可,效率高。
  2. 使用中序遍历出来的数据是有序的。

缺点:

  1. 结点的值不允许修改,否则破坏树的结构。

2. 二叉搜索树的插入

二叉搜索树的插入很简单,首先用插入的值从根结点开始比较。插入值小于结点值向左,插入值大于结点值向右,直到结点的左孩子或右孩子为空时结束,为空的位置就是插入的位置。

在这里插入图片描述

4作为插入结点的值,先找到6是插入结点的父结点,再判断4和6的大小关系,4<6,所以插入在6的左边。

在这里插入图片描述

7作为插入结点的值,先找到6是插入结点的父结点,再判断7和6的大小关系,7>6,所以插入在6的右边。

3. 二叉搜索树的删除

二叉搜索的删除需要分两种情况:

3.1 删除的结点是叶子结点

如果删除的结点是叶子结点,将该结点的父结点指针制空,再释放该结点即可。

在这里插入图片描述

3.2 删除的结点不是叶子结点

如果删除的结点不是叶子结点,可以分为三种情况讨论:

3.2.1 左子树为空

如果删除的结点的左子树为空,此时需要判断删除结点与其父子树的关系:我是父结点的左孩子,就让父结点的左指向我的右子树;我是父结点的右孩子,就让父结点的右指向我的右子树

在这里插入图片描述

在这里插入图片描述

3.2.2 右子树为空

右子树为空,原理与上相同,只是父结点改变的是左的指向。

在这里插入图片描述

在这里插入图片描述

3.2.3 左右子树不为空

如果删除结点的左右子树都不为空,那么此时就需要使用替换法的思想。替换法可以使用左子树的最大结点或右子树的最小结点作为替换结点来替换当前结点,再将替换结点删除。所谓“替换”在实际操作中不是把两个结点的值互换,而是将替换结点的值赋给原删除结点,因为替换节点最终要删除,所以不必要对其进行真正的替换操作。

使用最左结点替换:

在这里插入图片描述

使用最右结点替换:

在这里插入图片描述

4.二叉搜索树的退化问题

二叉搜索树的最优情况下,查找效率为logN。但当插入的顺序有序或部分有序时,二叉搜索树的查找效率会下降,极端情况下会退化至N

在这里插入图片描述

按{10,9,8,7,6,5,4}的顺序插入,导致二叉搜索树完全退化。

5. 参考代码

template<class K, class V>
struct BSTreeNode
{BSTreeNode<K, V>* _left;BSTreeNode<K, V>* _right;K _key;V _value;BSTreeNode(const K& key,const V& value):_left(nullptr),_right(nullptr),_key(key),_value(value){}
};template<class K, class V>
class BSTree
{typedef BSTreeNode<K, V> Node;
public:bool Insert(const K& key, const V& value){if (_root == nullptr){_root = new Node(key, value);return true;}Node* parent = nullptr;Node* cur = _root;while (cur){if (cur->_key < key){parent = cur;cur = cur->_right;}else if (cur->_key > key){parent = cur;cur = cur->_left;}else{return false;}}cur = new Node(key, value);{if (parent->_key < key){parent->_right = cur;}else{parent->_left = cur;}return true;}}Node* Find(const K& key){Node* cur = _root;while (cur){if (cur->_key > key){cur = cur->_left;}else if (cur->_key < key){cur = cur->_right;}else{return cur;}}return nullptr;}bool Erase(const K& key){//先找到该结点Node* cur = _root;Node* parent = cur;while (cur){if (cur->_key > key){parent = cur;cur = cur->_left;}else if (cur->_key < key){parent = cur;cur = cur->_right;}else{//如果删除的是叶子结点,直接删除if (cur->_left == nullptr && cur->_right == nullptr){if (cur == parent->_left)parent->_left = nullptr;else if (cur == parent->_right)parent->_right = nullptr;delete cur;}//如果左为空else if (cur->_left == nullptr){if (cur == _root){_root = cur->_right;}else{if (cur == parent->_left){parent->_left = cur->_right;}else if (cur == parent->_right){parent->_right = cur->_right;}}delete cur;}//如果右为空else if (cur->_right == nullptr){if (cur == _root){_root = cur->_left;}else{if (cur == parent->_left){parent->_left = cur->_left;}else if (cur == parent->_right){parent->_right = cur->_left;}}delete cur;}// 如果左右都不为空else{//查找右子树的最左结点替换Node* RightMinParent = cur;Node* RightMin = cur->_right;while (RightMin->_left){RightMinParent = RightMin;RightMin = RightMin->_left;}cur->_key = RightMin->_key;cur->_value = RightMin->_key;cur->_value = RightMin->_value;if (RightMinParent->_left == RightMin){RightMinParent->_left = nullptr;}else{RightMinParent->_right = nullptr;}delete RightMin;}return true;}}return false;}void _InOrder(Node* root){if (root == nullptr){return;}_InOrder(root->_left);cout << root->_key << ":" << root->_value << endl;_InOrder(root->_right);}void InOrder(){_InOrder(_root);cout << endl;}
private:Node* _root = nullptr;
};
http://www.zhongyajixie.com/news/16743.html

相关文章:

  • 用手机怎么做网站企业营销推广方案
  • 免费二级网站seo关键字优化
  • 3g 手机网站深圳网站优化网站
  • 网站建设公司哪家企业网站建设方案书
  • 营销型网站建设的特色网上广告宣传怎么做
  • html5手机网站开发视频搭建一个网站平台需要多少钱
  • dw软件网站建设教程视频seo是什么姓
  • 免费ps模板下载网站品牌营销策划公司排名
  • 在b2c电商网站上购物时提供的送货推广广告
  • 网站添加视频免费seo工具
  • 做跨境网站注意事项链接交换
  • .net网站设计知名网站
  • 科技成果转化网站建设百度官方免费下载安装
  • 怎么注册网自己的网站网店推广网站
  • 1688一件代发批发网郑州网络seo公司
  • 做网站最好的软件上海seo网站优化软件
  • 为什么一个网站做中英文双语版外贸平台有哪些比较好
  • 个人网站效果图咋做中国十大门户网站排行
  • 安全的响应式网站建设百度推广客户端下载安装
  • 整个网站与网站模板的区别拉新app渠道
  • wordpress入门网站seo检测工具
  • 湖南响应式网站哪里有市场调研报告模板
  • 广州网站建设 企业app代理推广合作
  • 个人网站模板免费下载路由器优化大师
  • 创建一个网站英语品牌推广外包
  • 淘宝客网站如何做推广方案黄冈网站推广
  • wordpress设置中文失败优化大师怎么提交作业
  • 全球最受欢迎的网站百度seo霸屏软件
  • 网站专题策划方案书网络营销常用的工具和方法
  • php对比java做网站抖音关键词排名查询工具