二叉搜索树的划分

划分操作为找出二叉树中第k个最小关键字的数据项,并通过一些操作使其位于树根。

为了找出一棵二叉搜索树中含有第k个最小关键字的数据项,我们检查左子树的节点数量。若那里存在k个节点,那么我们返回树根处的数据项。否则,若左子树拥有k个以上节点,我们就递归地在那里寻找第k个最小的节点。如果这两个条件都不成立,则左子树拥有t个元素且t<k,二叉搜索树中第k个最小元素就是右子树的第k-t-1个最小元素。找到该元素后,递归的通过根插入中的旋转操作使其成为整棵树的根。

复制代码
 1 private:
 2     Item selectR(link h, int k)
 3     { if (h == 0) return nullItem;
 4        int t = (h->l == 0) ? 0:h->l->N;
 5        if (t > k) return selectR(h->l, k);
 6        if (t < k) return selectR(h->r, k-t-1);
 7        return h->item;
 8      }
 9 public:
10     Item select(int k)
11     { return selectR(head, k);}
复制代码
1 void partR(link& h, int k)
2 { int t = (h->l == 0) ? 0:h->l->N;
3    if (t > k)
4    { partR(h->l, k); rotR(h);}
5    if (t < k)
6    { partR(h->r, k-t-1); rotL(h);}
7 }

 

posted @   ~宁静致远~  阅读(178)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示