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

做网站实时数据用接口郑志平爱站网创始人

做网站实时数据用接口,郑志平爱站网创始人,app网站建设需要什么,商城app制作教程一、概念 二叉搜索树又称二叉排序树,它或者是一棵空树,或者具有以下性质的二叉树: 若它的左子树不为空,则左树上所有节点的值都小于根节点的值。 若它的右子树不为空,则右子树上所有节点的值都大于根节点的值。 它…

一、概念

二叉搜索树又称二叉排序树,它或者是一棵空树,或者具有以下性质的二叉树:

若它的左子树不为空,则左树上所有节点的值都小于根节点的值。

若它的右子树不为空,则右子树上所有节点的值都大于根节点的值。

它的左右子树也分别为二叉搜索树。最多找O(N)。

二、查找、插入、删除

插入

bool Insert(K& k)
{if (_root == nullptr){_root = new BSNode(k);return true;}BSNode* cur = _root;BSNode* parent = nullptr;while (cur){if (cur->_k < k){parent = cur;cur = cur->_right;}else if (cur->_k > k){parent = cur;cur = cur->_left;}}if (parent->_k < k){parent->_right = new BSNode(k);}else if (parent->_k > k){parent->_left = new BSNode(k);}else{return false;}return true;
}

查找

bool Find(K k)
{BSNode* cur = _root;while (cur){if (cur->_k < k){cur = cur->_right;}else if (cur->_k > k){cur = cur->_left;}else{return true;}}return false;
}

删除

依次删除7、14、3、8。7和14属于直接删除的场景

3、8属于需要替换法进行删除的场景。

1、没有孩子

2、一个孩字

3、两个孩子,需要进行替换,也就是替换法,用左子树的最大节点或者右子树的最小节点。

最大节点为最右节点,最小节点就是最左节点 ,还需要处理要删除的节点为根节点,它没有左子树或者没有右子树的情况。

还有一种情况就是leftmax就是root的左子树的根,此时parent为nullptr所以我们需要让parent = cur

void Erase(K& k)
{BSNode* cur = _root;BSNode* parent = nullptr;while (cur){if (cur->_k < k){parent = cur;cur = cur->_right;}else if (cur->_k > k){parent = cur;cur = cur->_left;}else{//开始托孤//要删除的节点,左孩子为空if (cur->_left == nullptr){//需要判断删除节点就是根节点的情况if (cur == _root){_root = cur->_right;}else{if (parent->_right == cur){parent->_right = cur->_right;}else{parent->_left = cur->_right;}}}else if (cur->_right == nullptr){if (cur == _root){_root = cur->_left;}else{if (parent->_right == cur){parent->_right = cur->_left;}else {parent->_left = cur->_left;}}}else //两个孩子的情况,就需要替代法来删除{//找到左子树中最大的节点BSNode* leftMax = cur->_left;//注意为什么这里等于cur;BSNode* parent = cur;  while (leftMax->_right){parent = leftMax;leftMax = leftMax->_right;}//找到以后把删除节点和leftmax节点的值做交换std::swap(cur->_k, leftMax->_k);//我们该把父亲的那个孩子和cur节点的孩子连接起来呢需要判断if (parent->_left == leftMax){parent->_left = leftMax->_left;}else{parent->_right = leftMax->_left;}cur = leftMax;}delete cur;cur = nullptr;}}
}

有序数组:二分查找,问题:插入删除效率不行

二叉搜索树:插入删除效率还行。

如果退化成下面的情况,插入删除的效率就变成了O(N),所以我们引出了AVL树红黑树B树系列。

接下来我们看一下递归版本的删除,插入和发现

bool _EraseR(BSNode*& root, const K& k)
{if (root == nullptr){return false;}if (root->_k < k){_EraseR(root->_right, k);}else if (root->_k > k){_EraseR(root->_left, k);}else{BSNode* del = root;if (root->_left == nullptr){root = root->_right;}else if (root->_right == nullptr){root = root->_left;}else{BSNode* leftMax = root->_left;while (leftMax->_right){leftMax = leftMax->_right;}std::swap(leftMax->_k, root->_k);return _EraseR(root->_left, k);}delete del;del = nullptr;return true;}
}
bool _InsertR(BSNode*& root,const K& k)
{if (root == nullptr){root = new BSNode(k);return true;}if (root->_k < k){_InsertR(root->_right, k);}else if (root->_k > k){_InsertR(root->_left, k);}else{return false;}
}
bool _FindR(BSNode* root, const K& k)
{if (root == nullptr)return false;BSNode* cur = root;if (cur->_k < k){_FindR(root->_right, k);}else if (cur->_k > k){_FindR(root->_left, k);}else{return true;}
}

http://www.dt0577.cn/news/27314.html

相关文章:

  • 做网站挂靠服务器什么好上海百度竞价点击软件
  • 广州建设企业网站国外友链买卖平台
  • 北京做网站的大公司南京今天重大新闻事件
  • 部门网站建设总结西安网站seo技术厂家
  • 百度采购网官方网站最新重大新闻
  • 新疆建设局网站首页网络营销的主要方式和技巧
  • 贵阳网站建设企业百度客户端电脑版
  • 北京网站的优化如何在百度免费发布广告
  • wordpress网站搬视频营销案例
  • 请人做网站要注意什么网站seo置顶
  • 北京市朝阳区网站制作公司网络营销推广合作
  • 在互易上做的网站如何修改搜索引擎
  • seo网站优化推广怎么做软文营销的三个层面
  • 网站页面可以用什么框架做seo推广经验
  • wordpress 导出 新闻巢湖seo推广
  • 金华做公司网站沈阳网站seo
  • 洛阳市网站建设网络营销考试题目及答案2022
  • 邯郸做wap网站价格注册教育培训机构需要什么条件
  • 郑州做网站企业汉狮深圳推广平台有哪些
  • 温州网站公司深圳优化公司统高粱seo
  • wordpress 缩略图 剪裁 位置海外seo是什么
  • 阜宁做网站工作室长春网站seo哪家好
  • 丰田车营销网站建设的纲要计划书创建网站
  • 动漫制作专业专升本去哪个专业成都网站优化排名推广
  • 昆明做网站推永州网站seo
  • 如何做网站答题领红包链接搜索引擎排名优化方法
  • 百度快照替代百度首页关键词优化
  • 建站网站和维护需要会什么兰州网络推广与营销
  • 惠州网页建站模板推广赚钱
  • 免费建站系统下载长沙本地推广联系电话