Skip to content

Commit 014bcb0

Browse files
authored
Create even-odd-tree.py
1 parent 3e4e670 commit 014bcb0

File tree

1 file changed

+37
-0
lines changed

1 file changed

+37
-0
lines changed

Python/even-odd-tree.py

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
# Time: O(n)
2+
# Space: O(w)
3+
4+
# Definition for a binary tree node.
5+
class TreeNode(object):
6+
def __init__(self, val=0, left=None, right=None):
7+
self.val = val
8+
self.left = left
9+
self.right = right
10+
11+
12+
class Solution(object):
13+
def isEvenOddTree(self, root):
14+
"""
15+
:type root: TreeNode
16+
:rtype: bool
17+
"""
18+
q = [root]
19+
is_odd = False
20+
while q:
21+
new_q = []
22+
prev = None
23+
for node in q:
24+
if is_odd:
25+
if node.val%2 or (prev and prev.val <= node.val):
26+
return False
27+
else:
28+
if not node.val%2 or (prev and prev.val >= node.val):
29+
return False
30+
if node.left:
31+
new_q.append(node.left)
32+
if node.right:
33+
new_q.append(node.right)
34+
prev = node
35+
q = new_q
36+
is_odd = not is_odd
37+
return True

0 commit comments

Comments
 (0)