LeetCode426 将二叉搜索树转化为排序的双向链表

leetcode.cn/problems/er...

解法一:中序遍历

go 复制代码
// Definition for a Node.
type Node struct {
    Val   int
    Left  *Node
    Right *Node
}

// treeToDoublyList 将二叉搜索树转换为循环双向链表
// 中序遍历BST得到有序节点,再调整指针形成双向循环链表
func treeToDoublyList(root *Node) *Node {
    if root == nil {
        return nil
    }
    
    var pre, head *Node  // pre: 前驱节点, head: 链表头节点
    inorder(root, &pre, &head)  // 中序遍历构建双向链表
    
    // 首尾相连形成循环链表
    if head != nil && pre != nil {
        head.Left = pre   // 头节点的左指针指向尾节点
        pre.Right = head  // 尾节点的右指针指向头节点
    }
    
    return head
}

// inorder 中序遍历二叉树,将节点转换为双向链表
// pre: 指向前驱节点的指针的指针,用于修改前驱节点
// head: 指向链表头节点的指针的指针,仅在第一个节点时赋值
func inorder(node *Node, pre **Node, head **Node) {
    if node == nil {
        return
    }
    
    // 1. 递归遍历左子树
    inorder(node.Left, pre, head)
    
    // 2. 中序位置,处理当前节点
    if *pre == nil {
        // 首次访问节点(最左叶子节点),标记为链表头
        *head = node
    } else { // 建立双向连接
        // 前驱节点的右指针指向当前节点
        (*pre).Right = node
        // 当前节点的左指针指向前驱节点
        node.Left = *pre
    }
    
    // 更新前驱节点为当前节点
    *pre = node
    
    // 3. 递归遍历右子树
    inorder(node.Right, pre, head)
}
相关推荐
程序员爱钓鱼2 小时前
Python编程实战 · 基础入门篇 | 元组(tuple)
后端·python·ipython
程序员爱钓鱼2 小时前
Python编程实战 · 基础入门篇 | 列表(list)
后端·python·ipython
掘金码甲哥6 小时前
两张大图一次性讲清楚k8s调度器工作原理
后端
间彧6 小时前
Stream flatMap详解与应用实战
后端
Dream it possible!6 小时前
LeetCode 面试经典 150_链表_合并两个有序链表(58_21_C++_简单)
leetcode·链表·面试·1024程序员节
间彧7 小时前
Java Stream流两大实战陷阱:并行流Parallel误用、List转Map时重复键异常
后端
tan180°8 小时前
Linux网络UDP(10)
linux·网络·后端·udp·1024程序员节
正经教主8 小时前
【Trae+AI】和Trae学习搭建App_03:后端API开发原理与实践(已了解相关知识的可跳过)
后端·express
shepherd1269 小时前
破局延时任务(上):为什么选择Spring Boot + DelayQueue来自研分布式延时队列组件?
java·spring boot·后端·1024程序员节
开心-开心急了9 小时前
Flask入门教程——李辉 第5章: 数据库 关键知识梳理
笔记·后端·python·flask·1024程序员节