【LeetCode114】二叉树展开为链表(递归)

简介: 不能使用先序遍历(根-左-右),因为顺序应该是 上-下-上 的2个过程(下探和回溯),所以使用后序遍历。递归的注意事项:不管函数内部细节如何处理,而是要看函数的作用、输入和输出。

1.题目


image.pngimage.png


2.思路

不能使用先序遍历(根-左-右),因为顺序应该是 上-下-上 的2个过程(下探和回溯),所以使用后序遍历。


递归的注意事项:不管函数内部细节如何处理,而是要看函数的作用、输入和输出。

递归flatten函数作用:将一个二叉树原地展开为链表

函数的输入:树的根结点

函数的输出:无


后序遍历,在“做事情”的步骤中,分为三步:

(1)将根结点的左子树变为链表

(2)将根结点的右子树变成链表

(3)将变成链表的右子树放在链表的左子树的最右边。


盗用leetcode“明知山有虎”用户的图:


image.png

3.代码

/**
 * 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:
    void flatten(TreeNode* root) {
        if(root==NULL){
            return;
        }
        //将根结点的左子树变成链表
        flatten(root->left);
        //将根结点的右子树变成链表
        flatten(root->right);
        TreeNode* temp=root->right;
        //把树的右边换成左边的链表
        root->right=root->left;
        //记得左边要置空
        root->left=NULL;
        //找到树的最右边的结点
        while(root->right!=NULL){
            root=root->right;
        }
        //把右边的链表接到刚才树的最右边的结点
        root->right=temp;
    }
};


相关文章
|
3月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
41 1
|
10天前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
3月前
【LeetCode 31】104.二叉树的最大深度
【LeetCode 31】104.二叉树的最大深度
28 2
|
3月前
【LeetCode 43】236.二叉树的最近公共祖先
【LeetCode 43】236.二叉树的最近公共祖先
24 0
|
3月前
【LeetCode 38】617.合并二叉树
【LeetCode 38】617.合并二叉树
20 0
|
3月前
【LeetCode 37】106.从中序与后序遍历构造二叉树
【LeetCode 37】106.从中序与后序遍历构造二叉树
27 0
|
3月前
【LeetCode 34】257.二叉树的所有路径
【LeetCode 34】257.二叉树的所有路径
24 0
|
3月前
【LeetCode 32】111.二叉树的最小深度
【LeetCode 32】111.二叉树的最小深度
20 0
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
130 2