-
Notifications
You must be signed in to change notification settings - Fork 61
Expand file tree
/
Copy path0331-verify-preorder-serialization-of-a-binary-tree.js
More file actions
38 lines (37 loc) · 1.25 KB
/
0331-verify-preorder-serialization-of-a-binary-tree.js
File metadata and controls
38 lines (37 loc) · 1.25 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
/**
* 331. Verify Preorder Serialization of a Binary Tree
* https://leetcode.com/problems/verify-preorder-serialization-of-a-binary-tree/
* Difficulty: Medium
*
* One way to serialize a binary tree is to use preorder traversal. When we encounter a non-null
* node, we record the node's value. If it is a null node, we record using a sentinel value such
* as '#'.
*
* For example, the above binary tree can be serialized to the string "9,3,4,#,#,1,#,#,2,#,6,#,#",
* where '#' represents a null node.
*
* Given a string of comma-separated values preorder, return true if it is a correct preorder
* traversal serialization of a binary tree.
*
* It is guaranteed that each comma-separated value in the string must be either an integer or
* a character '#' representing null pointer.
*
* You may assume that the input format is always valid.
* For example, it could never contain two consecutive commas, such as "1,,3".
* Note: You are not allowed to reconstruct the tree.
*/
/**
* @param {string} preorder
* @return {boolean}
*/
var isValidSerialization = function(preorder) {
let result = 1;
for (const node of preorder.split(',')) {
if (result) {
result += node === '#' ? -1 : 1;
} else {
return false;
}
}
return result < 1;
};