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

DAY21-二叉树

LeetCode538.把二叉搜索树转换为累加树

    public TreeNode convertBST(TreeNode root) {reverseIn(root);return root;}public Integer value=0,flag=0;public void reverseIn(TreeNode root) {if(root==null) return ;reverseIn(root.right);if(flag==0) {value=root.val;flag=1;}else {value+=root.val;root.val=value;}reverseIn(root.left);}

LeetCode108.将有序数组转换为二叉搜索树

    public TreeNode sortedArrayToBST(int[] nums) {return builder(nums,0,nums.length-1);}public TreeNode builder(int[]nums,int start,int end) {if(end<start) return null;if(start==end) return new TreeNode(nums[start]);int min = (end+start)/2;TreeNode root = new TreeNode(nums[min]);root.left=builder(nums,start,min-1);root.right=builder(nums,min+1,end);return root;}

LeetCode669.修剪二叉搜索树

	public TreeNode deleteNode(TreeNode root, int key) {// root为空情况if (root == null) return null;// 如果要删除的节点是根节点,并且只有一个孩子或者没有孩子if (root.val == key) {if (root.left == null) return root.right;if (root.right == null) return root.left;// 找到右子树的最左节点TreeNode minRight = root.right;while (minRight.left != null) {minRight = minRight.left;}minRight.left = root.left;return root.right;}// 保存根节点TreeNode head = root;TreeNode temp = root;// 找到要删除的节点while (root != null && root.val != key) {temp = root;if (root.val > key) {root = root.left;} else {root = root.right;}}// 不存在 key 节点if (root == null) return head;// 删除节点if (root.left == null && root.right == null) {if (temp.left == root) {temp.left = null;} else {temp.right = null;}} else if (root.left == null) {if (temp.left == root) {temp.left = root.right;} else {temp.right = root.right;}} else if (root.right == null) {if (temp.left == root) {temp.left = root.left;} else {temp.right = root.left;}} else {TreeNode minRight = root.right;while (minRight.left != null) {minRight = minRight.left;}minRight.left = root.left;if (temp.left == root) {temp.left = root.right;} else {temp.right = root.right;}}return head;}public TreeNode trimBST(TreeNode root, int low, int high) {head=root;in(root,low,high);return head;}public TreeNode head = null;public void in(TreeNode root,int low,int high) {if(root==null) return;in(root.left,low,high);if(root.val<low||root.val>high) {head = deleteNode(head, root.val);}in(root.right,low,high);}

http://www.lryc.cn/news/405784.html

相关文章:

  • java面试-场景题
  • 【TORCH】matplotlib绘制一条横线的两种方法
  • 深入浅出mediasoup—WebRtcTransport
  • 如何让局域网中的其他电脑访问VMWare虚拟机上的Windows虚拟系统
  • 旧电脑回收前怎么清除数据
  • python——TinyDB
  • 【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第三篇 嵌入式Linux驱动开发篇-第三十八章 驱动模块编译进内核
  • Mailspring搭建安装教程:打造个性邮件体验
  • 【分布式锁】Redission实现分布式锁
  • UE4/5 对话系统
  • Golang | Leetcode Golang题解之第275题H指数II
  • Python—面向过程编程,详细讲解(类和实例,初始化函数,类中封装数据与操作)
  • Linux云计算 |【第一阶段】SERVICES-DAY2
  • el-upload照片墙自定义上传多张图片(手动一次性上传多张图片)包含图片回显,删除
  • 三星Unpacked发布会即将举行:有新款折叠屏手机,还有智能戒指
  • 【Python】Matplotlib简要教程
  • 数驭未来,景联文科技构建高质大模型数据库
  • 视频汇聚平台EasyCVR启动出现报错“cannot open shared object file”的原因排查与解决
  • VMware 安装完,设备管理器中没有虚拟网卡(vmnet0、wmnet1、vmnet8) / 虚拟网络编辑器中没有桥接模式
  • 构建高效Node.js中间层:探索请求合并转发的艺术
  • 中断和EXIT原理介绍
  • vcpkg或者命令行需要设置代理时如何设置
  • tensorflow安装及数据操作----学习笔记(一)
  • 顺序表和单链表的经典算法题
  • python基础知识点(蓝桥杯python科目个人复习计划71)
  • 【大数据专题】Flink题库
  • Python鲁汶意外莱顿复杂图拓扑分解算法
  • 【C++】类和对象之继承
  • 如何在LlamaIndex中使用RAG?
  • css气泡背景特效