首页 > 其他分享 >【二叉树】两棵二叉搜索树中的所有元素

【二叉树】两棵二叉搜索树中的所有元素

时间:2022-10-24 19:33:12浏览次数:49  
标签:arr TreeNode val self 二叉 二叉树 c2 c1 树中


0x00 题目

给你 ​​root1​​​ 和 ​​root2​​​ 这两棵二叉搜索树
请你返回一个列表
其中包含 ​​​两棵树​​​ 中的所有整数并按 ​​升序​​ 排序


0x01 思路

二叉搜索树​​中序遍历​​​是一个升序数组
得到 ​​​2​​​ 个升序数组后
再通过​​​比较​​​大小
把结果添加到​​​新​​数组中


0x02 解法

语言:​​Swift​

树节点:​​TreeNode​

public class TreeNode {
public var val: Int
public var left: TreeNode?
public var right: TreeNode?
public init() { self.val = 0; self.left = nil; self.right = nil; }
public init(_ val: Int) { self.val = val; self.left = nil; self.right = nil; }
public init(_ val: Int, _ left: TreeNode?, _ right: TreeNode?) {
self.val = val
self.left = left
self.right = right
}
}

解法:

func getAllElements(_ root1: TreeNode?, _ root2: TreeNode?) -> [Int] {
var arr1: [Int] = []
var arr2: [Int] = []

// 中序遍历
func inorder(_ root: TreeNode?, _ arr: inout [Int]) {
guard let r = root else { return }

inorder(r.left, &arr)
arr.append(r.val)
inorder(r.right, &arr)
}

// 得到 2 个升序数组
inorder(root1, &arr1)
inorder(root2, &arr2)

// 比较大小,放入新数组
var c1 = 0, c2 = 0
var arr: [Int] = []
while c1 < arr1.count && c2 < arr2.count {
if arr1[c1] < arr2[c2] {
arr.append(arr1[c1])
c1 += 1
}else{
arr.append(arr2[c2])
c2 += 1
}
}

// 数组1 还有元素
while c1 < arr1.count {
arr.append(arr1[c1])
c1 += 1
}

// 数组2 还有元素
while c2 < arr2.count {
arr.append(arr2[c2])
c2 += 1
}

return arr
}

0x03 我的小作品

欢迎体验我的作品之一:​​小编辑器-XCompiler​​​ 在线编辑器,包含多种语言,多达 20 种
​App Store​​ 搜索即可~



标签:arr,TreeNode,val,self,二叉,二叉树,c2,c1,树中
From: https://blog.51cto.com/u_15844020/5791039

相关文章

  • 【二叉树】删点成林
    0x00题目给出二叉树的根节点​​root​​​树上每个节点都有一个不同的值如果节点值在​​to_delete​​中出现我们就把该节点从树上​​删去​​最后得到一个森林(......
  • 【二叉树】二叉树中的最长交错路径
    0x00题目给你一棵以​​root​​为根的二叉树,二叉树中的交错路径定义如下:选择二叉树中​​任意​​​节点和一个方向(​​左​​​或者​​右​​​)如果前进方向为​​......
  • 【二叉树】最大层内元素和
    0x00题目给你一个二叉树的根节点​​root​​​设根节点位于二叉树的第​​1​​层而根节点的子节点位于第​​2​​层依此类推请返回层内元素之和​​​最大​​......
  • 数据结构---二叉树
    二叉树的结构体:左右子树指针(Tree*) 值(int)typedefstructTree{chardata;structTree*lchild,*rchild;}*BiTree;二叉树的先序创建BiTreeCreate(......
  • 2022.10.20-C 二叉树
    题意有一颗二叉树,满足一个结点要么是叶子结点,要么有两个儿子。同时,不存在一个叶子结点,使得它到根的路径上经过了\(\gem\)条向左的边。(左右子树有区别)对于\(1\lek\l......
  • 数据结构【C语言版】二叉树的结构和遍历的实现
    数据结构【C语言版】二叉树的结构和遍历的实现1.二叉树的存储结构二叉树一般分为两种存储结构,一种是顺序结构,一种是链表结构。顺序结构顺序结构存储就是使用数组来......
  • #yyds干货盘点# 动态规划专题:有多少个不同的二叉搜索树
    1.简述:描述给定一个由节点值从1到n的n个节点。请问由多少种不同的方法用这n个节点构成互不相同的二叉搜索树。数据范围: 输入描述:仅一行输入一个正整数n,表示节点......
  • Madoka and the Sixth-graders (全排列队列,每一个点可以向外连1条线题型+倍增法处理
    题意:Madoka的教室里有 nn 个座位,一开始,编号为 ii 的座位上坐着编号为 b_i(1\leb_i\len)bi​(1≤bi​≤n) 的同学。门外有排成一队的,编号从 n+1n+1 开始的,......
  • 二叉树的右视图
    给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。 publicList<Integer>rightSideView(TreeNoderoot){......
  • 【算法】算法题目三道模拟计算器,设计学生类和子类,二叉树开为链表
    算法题目描述算法知识点如下:模拟计算器,类型:算法初阶,比较简单。设计学生类和子类,类型:基础知识,比较简单。二叉树开展为链表,类型:栈,树,中等难度。第一题算法题目描述模拟简单的......