-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLeetNode.cs
80 lines (67 loc) · 2.19 KB
/
LeetNode.cs
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
using System.Linq;
using System.Collections.Generic;
namespace LeetNode
{
public class Program
{
static void Main(string[] args)
{
var root = new LeetNode().BuildeTree(new int?[]
{
17, 46, 44, 17, null, 21, 23, null, null, 50, 48, 46, 44, 5, null, 7, null, 11, null, 13, null, null, null, null, null, null, null, 17
});
}
}
/**
* Definition for a binary tree node. */
public class TreeNode
{
public int val;
public TreeNode left;
public TreeNode right;
public TreeNode(int val = 0, TreeNode left = null, TreeNode right = null)
{
this.val = val;
this.left = left;
this.right = right;
}
public override string ToString()
{
return $"Val: {val}, left: {left?.val.ToString() ?? 'n'.ToString()}, right: {right?.val.ToString() ?? 'n'.ToString()}";
}
}
public class LeetNode
{
public TreeNode BuildeTree(int?[] array)
{
if (array.Length == 0 || array[0] is null) return null;
List<TreeNode> level = new List<TreeNode>() { new TreeNode(array[0].Value) };
int taken = 1;
var root = level.Single();
while (level.Count > 0)
{
List<TreeNode> nextLevel = new List<TreeNode>();
foreach (var node in level)
{
if (taken == array.Length) break;
var leftVal = array.Skip(taken++).Take(1).Single();
if (leftVal != null)
{
node.left = new TreeNode(leftVal.Value);
nextLevel.Add(node.left);
}
if (taken == array.Length) break;
var rigthVal = array.Skip(taken++).Take(1).Single();
if (rigthVal != null)
{
node.right = new TreeNode(rigthVal.Value);
nextLevel.Add(node.right);
}
}
level = nextLevel;
}
return root;
}
}
}