leetcode 算法题558 (简单141) 四叉树交集
- 题目介绍
四叉树是一种树数据,
其中每个结点恰好有四个子结点:
topLeft、topRight、bottomLeft 和 bottomRight。四
叉树通常被用来划分一个二维空间,
递归地将其细分为四个象限或区域。
我们希望在四叉树中存储 True/False 信息。
四叉树用来表示 N * N 的布尔网格。
对于每个结点,
它将被等分成四个孩子结点直到这个区域内的值都是相同的。
每个节点都有另外两个布尔属性:
isLeaf 和 val。
当这个节点是一个叶子结点时 isLeaf 为真。
val 变量储存叶子结点所代表的区域的值。
例如,下面是两个四叉树 A 和 B:
A:
+-------+-------+ T: true
| | | F: false
| T | T |
| | |
+-------+-------+
| | |
| F | F |
| | |
+-------+-------+
topLeft: T
topRight: T
bottomLeft: F
bottomRight: F
B:
+-------+---+---+
| | F | F |
| T +---+---+
| | T | T |
+-------+---+---+
| | |
| T | F |
| | |
+-------+-------+
topLeft: T
topRight:
topLeft: F
topRight: F
bottomLeft: T
bottomRight: T
bottomLeft: T
bottomRight: F
你的任务是实现一个函数,
该函数根据两个四叉树返回表示这两个四叉树的逻辑或(或并)的四叉树。
A: B: C (A or B):
+-------+-------+ +-------+---+---+ +-------+-------+
| | | | | F | F | | | |
| T | T | | T +---+---+ | T | T |
| | | | | T | T | | | |
+-------+-------+ +-------+---+---+ +-------+-------+
| | | | | | | | |
| F | F | | T | F | | T | F |
| | | | | | | | |
+-------+-------+ +-------+-------+ +-------+-------+
- 提示
- A 和 B 都表示大小为 N * N 的网格。
- N 将确保是 2 的整次幂。
- 如果你想了解更多关于四叉树的知识,你可以参考这个 wiki 页面。
- 逻辑或的定义如下:如果 A 为 True ,或者 B 为 True ,或者 A 和 B 都为 True,则 “A 或 B” 为 True。
- 解法一
/**
* // Definition for a QuadTree node.
* function Node(val,isLeaf,topLeft,topRight,bottomLeft,bottomRight) {
* this.val = val;
* this.isLeaf = isLeaf;
* this.topLeft = topLeft;
* this.topRight = topRight;
* this.bottomLeft = bottomLeft;
* this.bottomRight = bottomRight;
* };
*/
/**
* @param {Node} quadTree1
* @param {Node} quadTree2
* @return {Node}
*/
var intersect = function(quadTree1, quadTree2) {
if(quadTree1.isLeaf) {
if(quadTree1.val) {
return quadTree1;
}
return quadTree2;
}
if(quadTree2.isLeaf) {
if(quadTree2.val) {
return quadTree2;
}
return quadTree1;
}
let topLeft = intersect(quadTree1.topLeft, quadTree2.topLeft);
let topRight = intersect(quadTree1.topRight, quadTree2.topRight);
let bottomLeft = intersect(quadTree1.bottomLeft, quadTree2.bottomLeft);
let bottomRight = intersect(quadTree1.bottomRight, quadTree2.bottomRight);
if(topLeft.isLeaf && topRight.isLeaf && bottomLeft.isLeaf && bottomRight.isLeaf && topLeft.val && topRight.val && bottomLeft.val && bottomRight.val) {
return new Node(true, true, null, null, null, null);
}
return new Node(topLeft.val || topRight.val || bottomLeft.val || bottomRight.val, false, topLeft, topRight, bottomLeft, bottomRight);;
};
执行用时 : 216 ms, 在所有 JavaScript 提交中击败了100.00%的用户
内存消耗 : 43.7 MB, 在所有 JavaScript 提交中击败了14.29%的用户