我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java算法中二叉树的练习题有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java算法中二叉树的练习题有哪些

小编给大家分享一下Java算法中二叉树的练习题有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

题目一

Java算法中二叉树的练习题有哪些

 解法

class Solution {    int i = 0;    int res = 0;    public int kthSmallest(TreeNode root, int k) {        method(root,k);        return res;    }     public void method(TreeNode root, int k){        if(root==null) return ;        method(root.left,k);        i++;        if(i==k){            res = root.val;            return ;        }        method(root.right,k);     }}

题目二

Java算法中二叉树的练习题有哪些

 解法

class Solution {    int sum = 0;    public TreeNode convertBST(TreeNode root) {        method(root);        return root;    }    public void method(TreeNode root) {        if(root==null){            return;        }        method(root.right);        sum+=root.val;        root.val = sum;        method(root.left);     }}

题目三

Java算法中二叉树的练习题有哪些

 解法

class Solution {    public boolean isValidBST(TreeNode root) {        return method(root,null,null);    }    public boolean method(TreeNode root,TreeNode min,TreeNode max){        if(root==null) return true;        if(min!=null&&root.val<=min.val) return false;        if(max!=null&&root.val>=max.val) return false;        return method(root.left,min,root)&&method(root.right,root,max);    }}

题目四

Java算法中二叉树的练习题有哪些

解法

class Solution {    public TreeNode searchBST(TreeNode root, int val) {        if(root==null) return null;        if(root.val==val) return root;        if(root.val>=val){            return searchBST(root.left,val);        }        if(root.val<val){            return searchBST(root.right,val);        }        return null;    }}

题目五

Java算法中二叉树的练习题有哪些

 解法

class Solution {    public TreeNode insertIntoBST(TreeNode root, int val) {        return  method(root,val);    }    public TreeNode method(TreeNode root, int val){        if(root==null) return new TreeNode(val);        if (root.val < val)             root.right = insertIntoBST(root.right, val);        if (root.val > val)             root.left = insertIntoBST(root.left, val);        return root;    }}

题目六

Java算法中二叉树的练习题有哪些

算法

class Solution {    public TreeNode deleteNode(TreeNode root, int key) {        if (root == null) return null;        if (root.val == key){            if (root.left == null) return root.right;            if (root.right == null) return root.left;            TreeNode minNode = getMin(root.right);            root.right = deleteNode(root.right, minNode.val);            minNode.left = root.left;            minNode.right = root.right;            root = minNode;        }else if(root.val>key){            root.left = deleteNode(root.left,key);        }else{            root.right = deleteNode(root.right,key);        }        return root;    }    TreeNode getMin(TreeNode node) {        while (node.left != null) node = node.left;        return node;    }   }

以上是“Java算法中二叉树的练习题有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java算法中二叉树的练习题有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java算法中二叉树的练习题有哪些

小编给大家分享一下Java算法中二叉树的练习题有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!题目一 解法/** * Definition for a bin
2023-06-29

Java中二叉树遍历的常用方法有哪些

这篇文章给大家分享的是有关Java中二叉树遍历的常用方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。采用前序遍历、中序遍历、后续遍历实现时,即便采用不同的实现方式(递归方式、非递归),它们的算法结构是有很
2023-06-15

Java二叉树的遍历方式有哪些

本篇内容主要讲解“Java二叉树的遍历方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java二叉树的遍历方式有哪些”吧!二叉树的四种遍历方式:二叉树的遍历(traversing bin
2023-06-25

python中有哪些类型的二叉树

python中有哪些类型的二叉树?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。python的五大特点是什么python的五大特点:1.简单易学,开发程序时,专注的是解决问题
2023-06-14

Java算法中数组与字符串练习题有哪些

这篇文章主要介绍Java算法中数组与字符串练习题有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目一解法class Solution { public int thirdMax(int[] nums) {
2023-06-29

python实现二叉搜索树的方法有哪些

这篇文章主要介绍“python实现二叉搜索树的方法有哪些”,在日常操作中,相信很多人在python实现二叉搜索树的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python实现二叉搜索树的方法有哪些
2023-07-06

java二叉树中数据插入算法的示例分析

这篇文章主要介绍java二叉树中数据插入算法的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!例题:leetcode 第701题二叉树插入数据题目:给定二叉搜索树(BST)的根节点和要插入树中的值,将值插入二叉
2023-06-22

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录