博客
关于我
每天一道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/

    你可能感兴趣的文章
    Mysql中各类锁的机制图文详细解析(全)
    查看>>
    MySQL中地理位置数据扩展geometry的使用心得
    查看>>
    Mysql中存储引擎简介、修改、查询、选择
    查看>>
    Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
    查看>>
    mysql中实现rownum,对结果进行排序
    查看>>
    mysql中对于数据库的基本操作
    查看>>
    Mysql中常用函数的使用示例
    查看>>
    MySql中怎样使用case-when实现判断查询结果返回
    查看>>
    Mysql中怎样使用update更新某列的数据减去指定值
    查看>>
    Mysql中怎样设置指定ip远程访问连接
    查看>>
    mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
    查看>>
    Mysql中文乱码问题完美解决方案
    查看>>
    mysql中的 +号 和 CONCAT(str1,str2,...)
    查看>>
    Mysql中的 IFNULL 函数的详解
    查看>>
    mysql中的collate关键字是什么意思?
    查看>>
    MySql中的concat()相关函数
    查看>>
    mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
    查看>>
    MySQL中的count函数
    查看>>
    MySQL中的DB、DBMS、SQL
    查看>>
    MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
    查看>>