-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path0094_binary_tree_inorder_traversal.py
More file actions
86 lines (64 loc) · 1.84 KB
/
0094_binary_tree_inorder_traversal.py
File metadata and controls
86 lines (64 loc) · 1.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
"""
94. Binary Tree Inorder Traversal
Companies
Given the root of a binary tree, return the inorder traversal of its nodes' values.
Example 1:
Input: root = [1,null,2,3]
Output: [1,3,2]
Example 2:
Input: root = []
Output: []
Example 3:
Input: root = [1]
Output: [1]
Constraints:
The number of nodes in the tree is in the range [0, 100].
-100 <= Node.val <= 100
"""
# Definition for a binary tree node.
from typing import List, Optional
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
class Solution:
def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
def deep(root: Optional[TreeNode]):
if root is None:
return
deep(root.left)
self.result.append(root.val)
deep(root.right)
self.result = []
deep(root)
print(self.result)
return self.result
def create_balanced_btree_from_sorted_list(self, nums: List[int]) -> TreeNode:
# Just for close the branch with no leaves at all
if len(nums) == 0:
return None
# if only 1 value = it means that there are no leaves
if len(nums) == 1:
return TreeNode(nums[0])
# MAIN: find the middle value in a list.
# Left side for the .left, right side for the .right.
# middle values as a val of the Node
i = int(len(nums) / 2)
return TreeNode(
nums[i],
self.create_balanced_btree_from_sorted_list(nums[:i]),
self.create_balanced_btree_from_sorted_list(nums[i+1:])
)
sol = Solution()
tree = TreeNode(
1,
None,
TreeNode(
2,
TreeNode(3),
None
)
)
assert sol.inorderTraversal(tree) == [1, 3, 2]
assert sol.inorderTraversal(None) == []