hello-algo/codes/javascript/modules/TreeNode.js

42 lines
940 B
JavaScript
Raw Normal View History

2022-12-04 12:26:09 +08:00
/**
* File: TreeNode.js
* Created Time: 2022-12-04
* Author: IsChristina (christinaxia77@foxmail.com)
*/
/**
* Definition for a binary tree node.
*/
class TreeNode {
val; // 节点值
left; // 左子节点指针
right; // 右子节点指针
height; //节点高度
constructor(val, left, right, height) {
this.val = val === undefined ? 0 : val;
this.left = left === undefined ? null : left;
this.right = right === undefined ? null : right;
this.height = height === undefined ? 0 : height;
}
2022-12-04 12:26:09 +08:00
}
/**
* Generate a binary tree given an array
* @param arr
* @return
*/
function arrToTree(arr, i = 0) {
if (i < 0 || i >= arr.length || arr[i] === null) {
return null;
2022-12-04 12:26:09 +08:00
}
let root = new TreeNode(arr[i]);
root.left = arrToTree(arr, 2 * i + 1);
root.right = arrToTree(arr, 2 * i + 2);
2022-12-04 12:26:09 +08:00
return root;
}
module.exports = {
2022-12-04 12:26:09 +08:00
TreeNode,
arrToTree,
};