当前位置: 首页 > news >正文

怎么用pf做网站提高工作效率

怎么用pf做网站,提高工作效率,做国外网站的站长,沈阳网站制作公司哪家好二叉树展开为链表 给你二叉树的根结点 root ,请你将它展开为一个单链表: 展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左子指针始终为 null 。展开后的单链表应该与二叉树 先序遍历 顺序相同…

二叉树展开为链表

给你二叉树的根结点 root ,请你将它展开为一个单链表:

  • 展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左子指针始终为 null 。
  • 展开后的单链表应该与二叉树 先序遍历 顺序相同。

示例1:
在这里插入图片描述
输入:root = [1,2,5,3,4,null,6]
输出:[1,null,2,null,3,null,4,null,5,null,6]

解题思路

展开二叉树为单链表可以使用前序遍历的方式来实现。

  • 1、对于当前节点,首先将其左子树展开为单链表,并将左子树的最右节点连接到当前节点的右子树上。
  • 2、然后将当前节点的右子树展开为单链表。
  • 3、如果左子树不为空,将当前节点的右子树设为展开后的左子树;否则,将左子树设为右子树。

Java实现

public class FlattenBinaryTreeToLinkedList {static class TreeNode {int val;TreeNode left;TreeNode right;TreeNode(int val) {this.val = val;}}public void flatten(TreeNode root) {if (root == null) {return;}flattenHelper(root);}private TreeNode flattenHelper(TreeNode node) {if (node == null) {return null;}//    1//   / \//  2   5// / \   \//3   4   6// 把2的右子树4放到2的左子树3的右子树上//      1//     / \//    2   5//   / \   \//  3   4   6//   \//    4//把2左子树3-4移到右子树下,把2的左子树置空//      1//     / \//    2   5//     \   \//      3   6//       \//        4//递归,把1的右子树5-6移到1的左子树2-3-4的右子树下//      1//     / \//    2   5//     \   \//      3   6//       \//        4//         \//          5//           \//            6//把1的左子树2-3-4-5-6替换到右子树上,把1的左子树置空//      1//       \//        2//         \//          3//           \//            4//             \//              5//               \//                6//链表符合前序遍历了,并且左子树全为null//下面是具体代码实现TreeNode leftTail = flattenHelper(node.left);TreeNode rightTail = flattenHelper(node.right);if (leftTail != null) {// 把右子树放到左子树的右子树上leftTail.right = node.right;// 把(带有右子树的)左子树赋给右子树node.right = node.left;// 右子树清空node.left = null;}//        在这里,rightTail 的优先级最高,然后是 leftTail,最后是 node。
//        这确保了在递归的过程中,当前子树展开后的链表的尾节点是按照
//        右子树、左子树、当前节点的顺序确定的。
//        这样的顺序保证了链表的正确连接,即右子树的尾部接在左子树的尾部,
//        而左子树的尾部接在当前节点的右侧。这样展开后的链表顺序符合二叉树的先序遍历。return (rightTail != null) ? rightTail : (leftTail != null) ? leftTail : node;}// 示例测试public static void main(String[] args) {FlattenBinaryTreeToLinkedList solution = new FlattenBinaryTreeToLinkedList();// 构造示例二叉树TreeNode root = new TreeNode(1);root.left = new TreeNode(2);root.right = new TreeNode(5);root.left.left = new TreeNode(3);root.left.right = new TreeNode(4);root.right.right = new TreeNode(6);// 调用展开方法solution.flatten(root);// 打印展开后的链表TreeNode current = root;while (current != null) {System.out.print(current.val + " ");current = current.right;}}
}

时间空间复杂度

  • 时间复杂度:O(n),其中n是二叉树中的节点数,每个节点都需要访问一次。
  • 空间复杂度:O(h),递归调用栈的深度为树的高度。
http://www.dt0577.cn/news/48246.html

相关文章:

  • 深圳网站开发培训seo软文是什么意思
  • 新站整站优化网络推广运营途径
  • 朝阳区社区建设网站百度热搜榜排名今日
  • vue做门户网站竞价推广开户
  • 惠阳网站优化sem模型
  • 网站建设的步骤目标规划网站有哪些平台
  • 广州专业网站制作哪家专业最近一周新闻热点回顾
  • 高端品牌的推广seo技术服务外包公司
  • 搜款网站一起做网店aso安卓优化
  • w3school网页制作证书廊坊百度seo公司
  • wordpress客户表单数据芜湖seo
  • 公司制做网站微信营销的方法
  • 手机网站主页面文艺免费网站在线客服软件
  • dz网站如何做301南昌seo实用技巧
  • 专业建设企业网站上海外包seo
  • 电子商城网站开发文档小红书推广方式有哪些
  • 郴州排名优化百度seo排名点击
  • 关于公司网络优化方案电脑优化用什么软件好
  • 如何做垃圾网站赚钱浙江百度推广
  • 简易网页制作工具seo网络推广优势
  • 贵阳网站建设哪家设计网站
  • 最低的成本做网站营销策划方案包括哪些内容
  • 电子商务网站开发指南软文标题大全
  • 网站开发后端框架什么意思google chrome官网下载
  • 做360网站优化快速百度官方网站
  • 如何做彩票网站的教程怎么样做推广
  • 品牌做网站还是appseo排名推广工具
  • 企业网站一般要素googleseo服务公司
  • 怎么给网站做404深圳关键词优化
  • 三级分销网站建设抖音关键词挖掘工具