欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Python实现查找二叉搜索树第k大的节点功能示例

程序员文章站 2023-11-05 20:46:28
本文实例讲述了python实现查找二叉搜索树第k大的节点功能。分享给大家供大家参考,具体如下: 题目描述 给定一个二叉搜索树,找出其中第k大的节点 就是一个中序遍...

本文实例讲述了python实现查找二叉搜索树第k大的节点功能。分享给大家供大家参考,具体如下:

题目描述

给定一个二叉搜索树,找出其中第k大的节点

Python实现查找二叉搜索树第k大的节点功能示例

就是一个中序遍历的过程,不需要额外的数组,便利到节点之后,k减一就行。

代码1

class treenode:
  def __init__(self, x):
    self.val = x
    self.left = none
    self.right = none
class solution:
  def __init__(self):
    self.k = 0
  def recursionkthnode(self, root):
    result = none
    if result == none and root.left:
      result = self.recursionkthnode(root.left)
    if result == none:
      if self.k == 1:
        return root
      self.k -= 1
    if result == none and root.right:
      result = self.recursionkthnode(root.right)
    return result
  def kthnode(self, root, k):
    if root == none:
      return none
    self.k = k
    return self.recursionkthnode(root)
root = treenode(5)
root.left = treenode(3)
root.left.left = treenode(2)
root.left.right = treenode(4)
root.right = treenode(7)
root.right.left = treenode(6)
root.right.right = treenode(8)
print(solution().kthnode(root,3).val)

output : 4

代码2

class treenode:
  def __init__(self, x):
    self.val = x
    self.left = none
    self.right = none
class solution:
  def __init__(self):
    self.k = 0
  def inorder(self, root):
    ans = none
    if root:
      if ans == none and root.left:
        ans = self.inorder(root.left)  #往左遍历
      if ans == none and self.k == 1:
        ans = root           #遍历到目标节点
      if ans == none and self.k != 1:   #没有遍历到目标节点,k--
        self.k -= 1
      if ans == none and root.right:   #往右遍历
        ans = self.inorder(root.right)
    return ans
  def kthnode(self, root, k):
    if root == none or k <= 0:
      return none
    self.k = k
    return self.inorder(root)

更多关于python相关内容感兴趣的读者可查看本站专题:《python数据结构与算法教程》、《python加密解密算法与技巧总结》、《python编码操作技巧总结》、《python函数使用技巧总结》、《python字符串操作技巧汇总》及《python入门与进阶经典教程

希望本文所述对大家python程序设计有所帮助。