首页 > 其他 > 详细

【leetcode】1305. All Elements in Two Binary Search Trees

时间:2020-01-04 23:21:08      阅读:81      评论:0      收藏:0      [点我收藏+]

题目如下:

Given two binary search trees root1 and root2.

Return a list containing all the integers from both trees sorted in ascending order.

Example 1:

技术分享图片

Input: root1 = [2,1,4], root2 = [1,0,3]
Output: [0,1,1,2,3,4]

Example 2:

Input: root1 = [0,-10,10], root2 = [5,1,7,0,2]
Output: [-10,0,0,1,2,5,7,10]

Example 3:

Input: root1 = [], root2 = [5,1,7,0,2]
Output: [0,1,2,5,7]

Example 4:

Input: root1 = [0,-10,10], root2 = []
Output: [-10,0,10]

Example 5:

技术分享图片

Input: root1 = [1,null,8], root2 = [8,1]
Output: [1,1,8,8] 

Constraints:

  • Each tree has at most 5000 nodes.
  • Each node‘s value is between [-10^5, 10^5].

解题思路:最简单的方法就是遍历两棵树,把值重新排序即可。

代码如下:

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution(object):
    res = []
    def recursive(self,node):
        self.res.append(node.val)
        if node.left != None:
            self.recursive(node.left)
        if node.right != None:
            self.recursive(node.right)
    def getAllElements(self, root1, root2):
        """
        :type root1: TreeNode
        :type root2: TreeNode
        :rtype: List[int]
        """
        self.res = []
        if root1 != None:
            self.recursive(root1)
        if root2 != None:
            self.recursive(root2)
        return sorted(self.res)

 

【leetcode】1305. All Elements in Two Binary Search Trees

原文:https://www.cnblogs.com/seyjs/p/12150563.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!