zoukankan      html  css  js  c++  java
  • bstToDoublyList

    bstToDoublyList

    bstToDoublyList

    Table of Contents

    1 描述

    将一个二叉查找树按照中序遍历转换成双向链表。

    2 样例

    给定一个二叉查找树:

        4
       / 
      2   5
     / 
    1   3
    

    返回 1<->2<->3<->4<->5

    3 解决方案

    做一个中序递归,用head保存首节点,用tail不断更新之后的每个节点。

    /**
     * Definition of TreeNode:
     * public class TreeNode {
     *     public int val;
     *     public TreeNode left, right;
     *     public TreeNode(int val) {
     *         this.val = val;
     *         this.left = this.right = null;
     *     }
     * }
     * Definition for Doubly-ListNode.
     * public class DoublyListNode {
     *     int val;
     *     DoublyListNode next, prev;
     *     DoublyListNode(int val) {
     *         this.val = val;
     *         this.next = this.prev = null;
     *     }
     * }
     */
    public class Solution {
        private DoublyListNode head = null;
        private DoublyListNode tail = null;
        /**
         * @param root: The root of tree
         * @return: the head of doubly list node
         */
        public DoublyListNode bstToDoublyList(TreeNode root) {
            // Write your code here
            if (null == root) {
                return null;
            }
            bstToDoublyList(root.left);
    
            DoublyListNode node = new DoublyListNode(root.val);
            if (null == head) {
                head = node;
                tail = node;
            } else {
                tail.next = node;
                node.prev = tail;
                tail = node;
            }
    
            bstToDoublyList(root.right);
    
            return head;
        }
    }
    

    Date: 2017-06-26 21:57

    Author: WEN YANG

    Created: 2017-06-26 Mon 22:03

    Emacs 25.2.1 (Org mode 8.2.10)

    Validate

  • 相关阅读:
    浅拷贝与深拷贝
    Hibernate入门(1)-第一个Hibernate程序
    Spring入门(10)-Spring JDBC
    【Java,IDEA】创建自己的代码模版快速生成
    【Java,IDEA】使用IDEA自动生成序列化ID
    【Project】原生JavaWeb工程 02 登陆业务的流程(第一阶段样例)
    【AJAX】Asynchronous JavaScript And XML (非同步的JS & XML)
    【JS】06 语法补充
    【JS】05 DOM 文档对象模型 P2 元素的CRUD、Dom集合对象
    【JS】04 DOM 文档对象模型 P1 查找元素、改变内容、绑定事件
  • 原文地址:https://www.cnblogs.com/yangwen0228/p/7082711.html
Copyright © 2011-2022 走看看