• JZ26 二叉搜索树与双向链表


    描述

    输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。如下图所示
     
    注意:
    1.要求不能创建任何新的结点,只能调整树中结点指针的指向。当转化完成以后,树中节点的左指针需要指向前驱,树中节点的右指针需要指向后继
    2.返回链表中的第一个节点的指针
    3.函数返回的TreeNode,有左右指针,其实可以看成一个双向链表的数据结构
    4.你不用输出或者处理,示例中输出里面的英文,比如"From left to right are:"这样的,程序会根据你的返回值自动打印输出
     
    示例:
    输入: {10,6,14,4,8,12,16}
    输出:From left to right are:4,6,8,10,12,14,16;From right to left are:16,14,12,10,8,6,4;
    解析:
    输入就是一棵二叉树,如上图,输出的时候会将这个双向链表从左到右输出,以及
    从右到左输出,确保答案的正确

    示例1

    输入:
    {10,6,14,4,8,12,16}
    返回值:
    From left to right are:4,6,8,10,12,14,16;From right to left are:16,14,12,10,8,6,4;

    示例2

    输入:
    {5,4,#,3,#,2,#,1}
    返回值:
    From left to right are:1,2,3,4,5;From right to left are:5,4,3,2,1;
    说明:
                        5
                      /
                    4
                  /
                3
              /
            2
          /
        1
    树的形状如上图  

    ==========================================================================================================================

    解题思路:
       对于这道题,解题思路是中序遍历,并且再增设一个pre前指针即可。在java中不能传地址,于是设私有变量再调用就可以。中序遍历遍历到最左叶子节点,此时将它的转设为头节点,root.left = pre; 再判断它是不是头节点,
    如果是,则不需要pre.left = root;如果不是,则需要。然后继续往后递归遍历即可。
  • 相关阅读:
    对于服务器AdminServer, 与计算机Machine-0相关联的节点管理器无法访问
    C语言面试题目之指针和数组
    Go数据类型之基本数据类型
    【转载】虚拟地址与虚拟内存的理解
    const变量可以修改么?
    【转载】内联函数 —— C 中关键字 inline 用法解析
    【转载】抓包工具tcpdump用法说明
    【转载】网络编程面试题
    [leetcode]颠倒整数
    [leetcode]反转字符串
  • 原文地址:https://www.cnblogs.com/hddandelion/p/15169891.html
Copyright © 2020-2023  润新知