北京网站如何制作,海外网络推广专员招聘,网站 英语,360建筑网app下载目录 题目描述#xff1a;114. 二叉树展开为链表#xff08;中等#xff09;题目接口解题思路代码 PS: 题目描述#xff1a;114. 二叉树展开为链表#xff08;中等#xff09;
给你二叉树的根结点 root #xff0c;请你将它展开为一个单链表#xff1a;
展开后的单链… 目录 题目描述114. 二叉树展开为链表中等题目接口解题思路代码 PS: 题目描述114. 二叉树展开为链表中等
给你二叉树的根结点 root 请你将它展开为一个单链表
展开后的单链表应该同样使用 TreeNode 其中 right 子指针指向链表中下一个结点而左子指针始终为 null 。展开后的单链表应该与二叉树 先序遍历 顺序相同。
LeetCode做题链接LeetCode-二叉树展开为链表
示例 1
输入root [1,2,5,3,4,null,6]
输出[1,null,2,null,3,null,4,null,5,null,6]示例 2
输入root []
输出[]示例 3
输入root [0]
输出[0]提示
树中结点数在范围 [0, 2000] 内
-100 Node.val 100进阶 你可以使用原地算法O(1) 额外空间展开这棵树吗
题目接口
/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right) {* this.val val;* this.left left;* this.right right;* }* }*/
class Solution {public void flatten(TreeNode root) {}
}解题思路
主要的思路是通过调整树的节点连接将二叉树展开为一个链表。具体步骤如下
从根节点开始检查左子树是否为空。如果左子树为空则将根节点更新为其右子节点继续处理下一个节点。如果左子树不为空找到左子树中最右边的节点。将原来的右子树接到左子树的最右边节点这样就将左子树的最深节点移动到了最右边。将左子树插入到右子树的位置即将左子树的最深节点作为新的根节点。重复以上步骤直到处理完所有节点。
通过这样的操作我们可以将二叉树展开为一个由左子树的节点组成的链表其中每个节点都包含左子树中的所有节点值。
代码
/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right) {* this.val val;* this.left left;* this.right right;* }* }*/
class Solution {public void flatten(TreeNode root) {while (root ! null) { // 如果左子树为空直接处理下一个节点if (root.left null) {root root.right;} else {// 找到左子树中最右边的节点TreeNode pre root.left;while (pre.right ! null) {pre pre.right;} // 将原来的右子树接到左子树的最右边节点pre.right root.right;// 将左子树插入到右子树的位置root.right root.left;root.left null;// 处理下一个节点root root.right;}}
}成功
PS:
感谢您的阅读如果您觉得本篇文章对您有所帮助请给予博主一个赞喔~