码迷,mamicode.com
首页 > 其他好文 > 详细

lintcode378- Convert Binary Search Tree to Doubly Linked Lis- medium

时间:2017-10-18 10:13:56      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:param   class   convert   logs   return   blog   bin   roo   实现   

Convert a binary search tree to doubly linked list with in-order traversal.

Example

Given a binary search tree:

    4
   /   2   5
 / 1   3

return 1<->2<->3<->4<->5

 

对每一个根节点来说,就是左边连上左子树的last(右下角),右边连上右子树的first(左下角)。然后返回自己的first(左下角)和last(右下角)。

用resultType来返回first last。

注意单侧null的细节处理。

 

1.自己实现

/**
 * 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 {
    /*
     * @param root: The root of tree
     * @return: the head of doubly list node
     */
     
    private class ResultType{
        public DoublyListNode first;
        public DoublyListNode last;
        public ResultType(DoublyListNode first, DoublyListNode last) {
            this.first = first;
            this.last = last;
        }
    }
    
    public DoublyListNode bstToDoublyList(TreeNode root) {
        // write your code here
        if (root == null) {
            return null;
        }
        ResultType result = helper(root);
        return result.first;
    }
    
    private ResultType helper(TreeNode root) {
        
        if (root == null) {
            return null;
        }
        
        DoublyListNode rootNode = new DoublyListNode(root.val);
        
        if (root.left == null && root.right == null) {
            return new ResultType(rootNode, rootNode);
        }
        
        ResultType left = helper(root.left);
        ResultType right = helper(root.right);
        
        if (left != null) {
            left.last.next = rootNode;
            rootNode.prev = left.last;
        }
        
        if (right != null) {
            rootNode.next = right.first;
            right.first.prev = rootNode;
        }
        
        DoublyListNode leftFirst = left == null ? rootNode : left.first;
        DoublyListNode rightLast = right == null ? rootNode : right.last;
        
        return new ResultType(leftFirst, rightLast);
    }
}

 

 

2. 九章实现:把 left == null 和left != null写到一个队里if clause里,更清楚,学习

但大体上这次我是自己写的答案和题解最接近的一次了!!!真的非常开心,而且一次AC。

class ResultType {
    DoublyListNode first, last;
    
    public ResultType(DoublyListNode first, DoublyListNode last) {
        this.first = first;
        this.last = last;
    }
}

public class Solution {
    /**
     * @param root: The root of tree
     * @return: the head of doubly list node
     */
    public DoublyListNode bstToDoublyList(TreeNode root) {  
        if (root == null) {
            return null;
        }
        
        ResultType result = helper(root);
        return result.first;
    }
    
    public ResultType helper(TreeNode root) {  
        if (root == null) {
            return null;
        }
        
        ResultType left = helper(root.left);
        ResultType right = helper(root.right);
        DoublyListNode node = new DoublyListNode(root.val);
        
        ResultType result = new ResultType(null, null);
        
        if (left == null) {
            result.first = node;
        } else {
            result.first = left.first;
            left.last.next = node;
            node.prev = left.last;
        }
        
        if (right == null) {
            result.last = node;
        } else {
            result.last = right.last;
            right.first.prev = node;
            node.next = right.first;
        }
        
        return result;
    }
}

 

lintcode378- Convert Binary Search Tree to Doubly Linked Lis- medium

标签:param   class   convert   logs   return   blog   bin   roo   实现   

原文地址:http://www.cnblogs.com/jasminemzy/p/7684861.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!