博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
力扣题解-114. 二叉树展开为链表(分治法思想,递归的方式求解)
阅读量:4300 次
发布时间:2019-05-27

本文共 1390 字,大约阅读时间需要 4 分钟。

题目:114. 二叉树展开为链表

给定一个二叉树,原地将它展开为一个单链表。

例如,给定二叉树

1   / \  2   5 / \   \3   4   6

将其展开为:

1 \  2   \    3     \      4       \        5         \          6

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/flatten-binary-tree-to-linked-list
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解

利用分治法思想递归法求解。

  1. divide

    将原始二叉树分为三个部分:根节点root,左子树和右子树。

  2. conquer

    递归地将左子树和右子树拉平,执行flatten(左子树),flatten(右子树)。

  3. combine

    将root的右子树接到左子树下方,然后将整个左子树作为右子树。

代码

/** * 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) {
return; } flatten(root->left); flatten(root->right); TreeNode* left = root->left; TreeNode* right = root->right; //找到左子树的最后节点last TreeNode* next = left; TreeNode* last = nullptr; while (next) {
last = next; next = next->right; } //将右子树拼接到左子树的最后 if (last) {
last->right = right; } else {
left = right; } root->left = nullptr; root->right = left; }};
你可能感兴趣的文章
管理网&业务网的一些笔记
查看>>
openstack报错解决一
查看>>
openstack报错解决二
查看>>
linux source命令
查看>>
openstack报错解决三
查看>>
乙未年年终总结
查看>>
子网掩码
查看>>
第一天上班没精神
查看>>
启动eclipse报错:Failed to load the JNI shared library
查看>>
eclipse安装插件的两种方式在线和离线
查看>>
linux下源的相关笔记(suse)
查看>>
linux系统分区文件系统划分札记
查看>>
Linux(SUSE 12)安装Tomcat
查看>>
Linux(SUSE 12)安装jboss4并实现远程访问
查看>>
Neutron在给虚拟机分配网络时,底层是如何实现的?
查看>>
netfilter/iptables全攻略
查看>>
Overlay之VXLAN架构
查看>>
Eclipse : An error occurred while filtering resources(Maven错误提示)
查看>>
在eclipse上用tomcat部署项目404解决方案
查看>>
web.xml 配置中classpath: 与classpath*:的区别
查看>>