Day 18 987. 二叉树的垂序遍历

987. 二叉树的垂序遍历

题目

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
给你二叉树的根结点 root ,

请你设计算法计算二叉树的 垂序遍历 序列。

对位于 (row, col) 的每个结点而言,

其左右子结点分别位于 (row + 1, col - 1) 和 (row + 1, col + 1) 。

树的根结点位于 (0, 0) 。

二叉树的垂序遍历从最左边的列开始直到最右边的列结束,

按列索引每一列上的所有结点,形成一个按出现位置从上到下排序的有序列表。

如果同行同列上有多个结点,则按结点的值从小到大进行排序。

返回二叉树的 垂序遍历 序列。

示例 1

输入:root = [3,9,20,null,null,15,7]
输出:[[9],[3,15],[20],[7]]
解释:
-1 :只有结点 9 在此列中。
0 :只有结点 315 在此列中,按从上到下顺序。
1 :只有结点 20 在此列中。
2 :只有结点 7 在此列中。

示例 2

输入:root = [1,2,3,4,5,6,7]
输出:[[4],[2],[1,5,6],[3],[7]]
解释:
-2 :只有结点 4 在此列中。
-1 :只有结点 2 在此列中。
0 :结点 156 都在此列中。
1 在上面,所以它出现在前面。
56 位置都是 (2, 0) ,所以按值从小到大排序,56 的前面。
1 :只有结点 3 在此列中。
2 :只有结点 7 在此列中。

示例 3

输入:root = [1,2,3,4,6,5,7]
输出:[[4],[2],[1,5,6],[3],[7]]
解释:
这个示例实际上与示例 2 完全相同,只是结点 56 在树中的位置发生了交换。
因为 56 的位置仍然相同,所以答案保持不变,仍然按值从小到大排序。
 
提示:

树中结点数目总数在范围 [1, 1000] 内
0 <= Node.val <= 1000

题目思路

  • 1、本质上还是 DFS 与 BFS 题目,此题目只是解决问题的方式要麻烦一点,所以花费时间较长,本质上应该属于中等题类,算不上难度的题目
  • 2、DFS 采用哈希表加优先队列,其中由于 c++的 priority_queue 的实现为大根堆,此题目属于小根堆的实现,所以使用 multiset(小根堆)实现。
  • 3、BFS 留待考研后再写,现在每日思考一个小时时间题目时间太多了。

代码块。

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
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) :
val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
typedef map<int, multiset<pair<int, int>>> maps;
void dfs(TreeNode* root, int x, int y, maps &mp)
{
if(root == nullptr) return;
mp[y].insert({x, root->val});
if(root -> left ) dfs(root -> left, x + 1, y - 1, mp);
if(root -> right) dfs(root -> right, x + 1, y + 1, mp);
}
vector<vector<int>> verticalTraversal(TreeNode* root)
{
maps mp;
dfs(root, 0, 0, mp);
vector<vector<int>> ans;
for(auto & [k, v] : mp)
{
vector<int> vs;
for(auto & p : v) vs.push_back(p.second);
ans.push_back(vs);
}
return ans;
}
};

复杂度

  • 时间复杂度:O(n*logn)

  • 空间复杂度:O(n)


Day 18 987. 二叉树的垂序遍历
https://chaggle.github.io/2021/09/27/Leetcode/91-day/day-18/
作者
chaggle
发布于
2021年9月27日
许可协议