我是靠谱客的博主 年轻项链,最近开发中收集的这篇文章主要介绍leetcode算法练习---二叉搜索树中第K小的元素题目描述思路代码补充-二叉树的中序遍历,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

BST中第K小的元素

  • 题目描述
  • 思路
  • 代码
  • 补充-二叉树的中序遍历

题目描述

给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找其中第 k 个最小元素(从 1 开始计数)。
在这里插入图片描述
在这里插入图片描述

思路

利用二叉搜索树的中序遍历是单调递增
则第K小的就是第K-1的值

在栈的帮助下,可以将方法一的递归转换为迭代,这样可以加快速度,因为这样可以不用遍历整个树,可以在找到答案后停止。

在这里插入图片描述

代码

public class Solution {
    public static void main(String[] args) {
        TreeNode treeNode_2=new TreeNode(2,null,null);
        TreeNode treeNode_4=new TreeNode(4,null,null);
        TreeNode treeNode_3=new TreeNode(3,treeNode_2,treeNode_4);
        TreeNode treeNode_7=new TreeNode(7,null,null);
        TreeNode treeNode_6=new TreeNode(6,null,treeNode_7);
        TreeNode treeNode_5=new TreeNode(5,treeNode_3,treeNode_6);
        int search_val = kthSmallest(treeNode_5, 3);
        System.out.println(search_val);
    }
    public static int kthSmallest(TreeNode root, int k) {
        LinkedList<TreeNode> stack = new LinkedList<TreeNode>();
        for (;;){
            while (root !=null){
                stack.add(root);
                root=root.left;
            }
            root=stack.removeLast();
            if(--k==0){
                return root.val;
            }
            root=root.right;
        }
    }

}


class TreeNode {
  int val;
  TreeNode left;
  TreeNode right;
  TreeNode() {}
  TreeNode(int val) { this.val = val; }
  TreeNode(int val, TreeNode left, TreeNode right) {
      this.val = val;
      this.left = left;
      this.right = right;
  }
}

补充-二叉树的中序遍历

和上边的是1个思路

package algorithm;

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;

public class Solution {
    public static void main(String[] args) {
        TreeNode treeNode_2=new TreeNode(2,null,null);
        TreeNode treeNode_4=new TreeNode(4,null,null);
        TreeNode treeNode_3=new TreeNode(3,treeNode_2,treeNode_4);
        TreeNode treeNode_7=new TreeNode(7,null,null);
        TreeNode treeNode_6=new TreeNode(6,null,treeNode_7);
        TreeNode treeNode_5=new TreeNode(5,treeNode_3,treeNode_6);
        List<Integer> inorder = inorder(treeNode_5);
        for (Integer item : inorder) {
            System.out.println(item);
        }
    }
    public static List<Integer> inorder(TreeNode root) {
        List<Integer> list=new ArrayList<>();
        LinkedList<TreeNode> stack = new LinkedList<TreeNode>();
        while (root!=null || !stack.isEmpty()){
            while (root !=null){
                stack.add(root);
                root=root.left;
            }
            root=stack.removeLast();
            list.add(root.val);
            root=root.right;
        }
        return list;
    }

}


class TreeNode {
  int val;
  TreeNode left;
  TreeNode right;
  TreeNode() {}
  TreeNode(int val) { this.val = val; }
  TreeNode(int val, TreeNode left, TreeNode right) {
      this.val = val;
      this.left = left;
      this.right = right;
  }
}

最后

以上就是年轻项链为你收集整理的leetcode算法练习---二叉搜索树中第K小的元素题目描述思路代码补充-二叉树的中序遍历的全部内容,希望文章能够帮你解决leetcode算法练习---二叉搜索树中第K小的元素题目描述思路代码补充-二叉树的中序遍历所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(62)

评论列表共有 0 条评论

立即
投稿
返回
顶部