博客
关于我
每天一道leetcode:剑指 Offer 36. 二叉搜索树与双向链表(中等&深度优先遍历&递归)
阅读量:433 次
发布时间:2019-03-06

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

为了将二叉搜索树转换为排序的循环双向链表,我们可以利用二叉搜索树的中序遍历特性。中序遍历的结果即为从小到大的顺序,这正好适合链表的元素排列方式。以下是详细的解决方案:

方法思路

  • 中序遍历:首先进行中序遍历,记录访问的节点顺序。中序遍历的结果就是从小到大排列的顺序,符合链表的元素排列需求。
  • 递归遍历:使用递归DFS(深度优先搜索)遍历二叉搜索树。在遍历过程中,记录当前节点和前驱节点,逐步构建链表。
  • 连接节点:在递归过程中,当前节点的前驱节点的右指向当前节点,当前节点的左指向前驱节点。这样逐步构建出链表。
  • 循环链表处理:在遍历结束后,将链表的头节点和最后一个节点相连,形成循环链表。
  • 解决代码

    class Node {
    int val;
    Node* left;
    Node* right;
    Node(int _val) {
    val = _val;
    left = null;
    right = null;
    }
    }
    class Solution {
    Node* pre;
    Node* head;
    void dfs(Node* cur) {
    if (cur == null) {
    return;
    }
    // 中序遍历处理左子树
    dfs(cur->left);
    // 当前节点的前驱是pre节点,当前节点的右指向pre
    if (pre != null) {
    pre->right = cur;
    } else {
    head = cur;
    }
    // 当前节点的左指向pre节点
    cur->left = pre;
    // 更新pre为当前节点
    pre = cur;
    // 处理右子树
    dfs(cur->right);
    }
    Node* treeToDoublyList(Node* root) {
    if (root == null) {
    return null;
    }
    dfs(root);
    // 头节点的左指向pre(即最后一个节点)
    head->left = pre;
    // 最后一个节点的右指向头节点,形成循环
    pre->right = head;
    return head;
    }
    }

    代码解释

  • Node类:定义了二叉搜索树的节点结构,包含值、左指针和右指针。
  • Solution类:包含递归函数dfs和转换函数treeToDoublyList
  • 递归函数dfs
    • 递归访问左子树。
    • 处理当前节点与前驱节点的连接。
    • 更新当前节点为前驱节点。
    • 递归访问右子树。
  • 转换函数treeToDoublyList
    • 初始化递归遍历。
    • 头节点的左指针指向最后一个节点。
    • 最后一个节点的右指针指向头节点,形成循环链表。
  • 链表连接:确保链表头尾相连,形成循环结构。
  • 通过上述方法,可以将二叉搜索树转换为循环双向链表,满足题目要求。

    转载地址:http://xbquz.baihongyu.com/

    你可能感兴趣的文章
    Linux下的系统监控与性能调优:从入门到精通
    查看>>
    LiveGBS user/save 逻辑缺陷漏洞复现(CNVD-2023-72138)
    查看>>
    localhost:5000在MacOS V12(蒙特利)中不可用
    查看>>
    mac mysql 进程_Mac平台下启动MySQL到完全终止MySQL----终端八步走
    查看>>
    Mac OS 12.0.1 如何安装柯美287打印机驱动,刷卡打印
    查看>>
    MangoDB4.0版本的安装与配置
    查看>>
    Manjaro 24.1 “Xahea” 发布!具有 KDE Plasma 6.1.5、GNOME 46 和最新的内核增强功能
    查看>>
    mapping文件目录生成修改
    查看>>
    MapReduce程序依赖的jar包
    查看>>
    mariadb multi-source replication(mariadb多主复制)
    查看>>
    MaterialForm对tab页进行隐藏
    查看>>
    Member var and Static var.
    查看>>
    memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
    查看>>
    memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
    查看>>
    Memcached:Node.js 高性能缓存解决方案
    查看>>
    memcache、redis原理对比
    查看>>
    memset初始化高维数组为-1/0
    查看>>
    Metasploit CGI网关接口渗透测试实战
    查看>>
    Metasploit Web服务器渗透测试实战
    查看>>
    Moment.js常见用法总结
    查看>>