LeetCode Notes 015

Construct Binary Tree from Inorder and Postorder Traversal

Given inorder and postorder traversal of a tree, construct the binary tree.

Note:
You may assume that duplicates do not exist in the tree.

For example, given

1
2
inorder = [9,3,15,20,7]
postorder = [9,15,7,20,3]

Return the following binary tree:

1
2
3
4
5
  3
/ \
9 20
/ \
15 7

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
/**
* Definition for a binary tree node.
* function TreeNode(val) {
* this.val = val;
* this.left = this.right = null;
* }
*/
/**
* @param {number[]} inorder
* @param {number[]} postorder
* @return {TreeNode}
*/
var buildTree = function(inorder, postorder) {
return dfs(inorder.length - 1, 0, inorder.length - 1);

function dfs(index, startPos, endPos) {
if (startPos > endPos)
return null;

var node = new TreeNode(postorder[index]);
var pos = inorder.indexOf(postorder[index], startPos);

node.left = dfs(index - (endPos - pos) - 1, startPos, pos - 1);
node.right = dfs(index - 1, pos + 1, endPos);

return node;
}
};

Construct Binary Tree from Inorder and Postorder Traversal

Given preorder and inorder traversal of a tree, construct the binary tree.

Note:
You may assume that duplicates do not exist in the tree.

For example, given

1
2
preorder = [3,9,20,15,7]
inorder = [9,3,15,20,7]

Return the following binary tree:

1
2
3
4
5
  3
/ \
9 20
/ \
15 7
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
/**
* Definition for a binary tree node.
* function TreeNode(val) {
* this.val = val;
* this.left = this.right = null;
* }
*/
/**
* @param {number[]} preorder
* @param {number[]} inorder
* @return {TreeNode}
*/
var buildTree = function(preorder, inorder) {
return dfs(0, 0, preorder.length - 1);

// the subTree values whose node value is preorder[index]
// inorder[startPos] - inorder[endPos]
function dfs(index, startPos, endPos) {
if (startPos > endPos)
return null;

var node = new TreeNode(preorder[index]);
var pos = inorder.indexOf(preorder[index], startPos);

// node's left subNode's value is preorder[index + 1]
// node's right subNode's value is preorder[index + pos - startPos + 1]
node.left = dfs(index + 1, startPos, pos - 1);
node.right = dfs(index + pos - startPos + 1, pos + 1, endPos);

return node;
}
};

Construct the Rectangle

For a web developer, it is very important to know how to design a web page’s size. So, given a specific rectangular web page’s area, your job by now is to design a rectangular web page, whose length L and width W satisfy the following requirements:

1
2
3
4
5
1. The area of the rectangular web page you designed must equal to the given target area.

2. The width W should not be larger than the length L, which means L >= W.

3. The difference between length L and width W should be as small as possible.

You need to output the length L and the width W of the web page you designed in sequence.

Example:

1
2
3
4
Input: 4
Output: [2, 2]
Explanation: The target area is 4, and all the possible ways to construct it are [1,4], [2,2], [4,1].
But according to requirement 2, [1,4] is illegal; according to requirement 3, [4,1] is not optimal compared to [2,2]. So the length L is 2, and the width W is 2.

Note:

  1. The given area won’t exceed 10,000,000 and is a positive integer
  2. The web page’s width and length you designed must be positive integers.
文章作者: Monad Kai
文章链接: onlookerliu.github.io/2018/03/20/LeetCode-Notes-015/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Code@浮生记
支付宝打赏
微信打赏