牛客——二叉树搜索树转换成排序双向链表

简介: 牛客——二叉树搜索树转换成排序双向链表

JZ36 二叉搜索树与双向链表

这道题要求空间复杂度为O(1),如果没有这个条件可以创建一个vector将所有结点放进去之后进行操作。

所以这道题的思路可以用一个节点来指向上一个经过的结点,用于链接两个结点。

我们创建出一个指针front,这个指针指向的是中序遍历中的指针的上一个位置,用于前后进行链接。

用递归。

遍历的结点遍历完左再向右,向右的过程中,正好到了4的位置,4的左指针指向前驱,前驱是什么都没有,所以指向空就可以了,然后让右指针指向父节点,这个时候我们并不知道父节点,那么这时可以将指针front指向这里,然后本身返回上一层访问的就是父节点(这里是6),这个时候本来是要访问右子树的,在这个过程中让front指针的右指针指向该节点,就完成了一次链接,以此循环就可以了。

最后一步退出之后front指向16的结点,该节点没有后继,所以不需要指向空指针。(这里其实随意)

/*
struct TreeNode {
  int val;
  struct TreeNode *left;
  struct TreeNode *right;
  TreeNode(int x) :
      val(x), left(NULL), right(NULL) {
  }
};*/
class Solution {
public:
  void linked(TreeNode* root, TreeNode*& front)
  {
    if(root == nullptr)
      return ;
    linked(root->left, front);
    root->left =  front;
    if(front)//如果front为空就说明不需要让front指向谁
      front->right = root;
    front = root;
    linked(root->right, front);
  }
    TreeNode* Convert(TreeNode* pRootOfTree) {
        TreeNode* front = nullptr;
    TreeNode* root = pRootOfTree;
    linked(root, front);
    while(root && root->left)//找到链表表头
      root = root->left;
    return root;
    }
};

这里的前缀结点指针front必须加一个引用,因为在递归的时候返回上一层要将front的位置也带回去,如果不带引用上一层储存的就不是当前层的front所指向的位置了。

相关文章
|
6月前
《剑指offer》——合并两个排序的链表
《剑指offer》——合并两个排序的链表
|
5月前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
1月前
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
49 0
|
1月前
|
算法
❤️算法笔记❤️-(每日一刷-83、删除排序链表中的重复项)
❤️算法笔记❤️-(每日一刷-83、删除排序链表中的重复项)
31 0
|
3月前
|
存储 算法
LeetCode第83题删除排序链表中的重复元素
文章介绍了LeetCode第83题"删除排序链表中的重复元素"的解法,使用双指针技术在原链表上原地删除重复元素,提供了一种时间和空间效率都较高的解决方案。
LeetCode第83题删除排序链表中的重复元素
|
3月前
|
Python
【Leetcode刷题Python】114. 二叉树展开为链表
LeetCode上114号问题"二叉树展开为链表"的Python实现,通过先序遍历二叉树并调整节点的左右指针,将二叉树转换为先序遍历顺序的单链表。
27 3
【Leetcode刷题Python】114. 二叉树展开为链表
|
3月前
|
存储 算法 Java
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
45 0
|
5月前
|
存储 人工智能 测试技术
每日练习之排序——链表的合并;完全背包—— 兑换零钱
每日练习之排序——链表的合并;完全背包—— 兑换零钱
33 2
|
5月前
|
存储 算法
数据结构和算法学习记录——二叉树的存储结构&二叉树的递归遍历(顺序存储结构、链表存储结构、先序中序后序递归遍历)
数据结构和算法学习记录——二叉树的存储结构&二叉树的递归遍历(顺序存储结构、链表存储结构、先序中序后序递归遍历)
62 0
数据结构和算法学习记录——二叉树的存储结构&二叉树的递归遍历(顺序存储结构、链表存储结构、先序中序后序递归遍历)
|
5月前
|
存储 SQL 算法
LeetCode 83题:删除排序链表中的重复元素【面试】
LeetCode 83题:删除排序链表中的重复元素【面试】