[leetcode]114. Flatten Binary Tree to Linked List@Java解题报告
2017-08-08 11:10
369 查看
https://leetcode.com/problems/flatten-binary-tree-to-linked-list/description/
Given a binary tree, flatten it to a linked list in-place.
For example,
Given
The flattened tree should look like:
click to show hints.
Hints:
If you notice carefully in the flattened tree, each node's right child points to the next node of a pre-order traversal.
本题有递归和循环解法
package go.jacob.day808;
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
/**
* 114. Flatten Binary Tree to Linked List
* @author Jacob
*
*/
public class Demo4 {
/*
* 解法一
* 递归解法
* 从尾到头逆序处理
*/
TreeNode pre=null;
public void flatten(TreeNode root) {
if(root==null)
return ;
flatten(root.right);
flatten(root.left);
root.left=null;
root.right=pre;
pre=root;
}
/*
* 解法二:循环求解
*/
public void flatten_1(TreeNode root) {
if(root==null)
return;
Stack<TreeNode> stack=new Stack<TreeNode>();
stack.push(root);
while(!stack.isEmpty()){
TreeNode node=stack.pop();
if(node.right!=null)
stack.push(node.right);
if(node.left!=null)
stack.push(node.left);
if(!stack.isEmpty())
node.right=stack.peek();
node.left=null;
}
}
/*
* 低效率解法
*/
public void flatten_2(TreeNode root) {
if(root==null)
return;
List<TreeNode> list=new ArrayList<TreeNode>();
Stack<TreeNode> stack=new Stack<TreeNode>();
stack.push(root);
TreeNode node=null;
while(!stack.isEmpty()||node!=null){
if(node==null){
node=stack.pop();
node=node.right;
}else{
stack.push(node);
list.add(node);
node=node.left;
}
}
TreeNode node1=null;
TreeNode node2=null;
for(int i=0;i<list.size()-1;i++){
node1=list.get(i);
node2=list.get(i+1);
node1.left=null;
node1.right=node2;
}
node2.left=null;node2.right=null;
}
}
Given a binary tree, flatten it to a linked list in-place.
For example,
Given
1 / \ 2 5 / \ \ 3 4 6
The flattened tree should look like:
1 \ 2 \ 3 \ 4 \ 5 \ 6
click to show hints.
Hints:
If you notice carefully in the flattened tree, each node's right child points to the next node of a pre-order traversal.
本题有递归和循环解法
package go.jacob.day808;
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
/**
* 114. Flatten Binary Tree to Linked List
* @author Jacob
*
*/
public class Demo4 {
/*
* 解法一
* 递归解法
* 从尾到头逆序处理
*/
TreeNode pre=null;
public void flatten(TreeNode root) {
if(root==null)
return ;
flatten(root.right);
flatten(root.left);
root.left=null;
root.right=pre;
pre=root;
}
/*
* 解法二:循环求解
*/
public void flatten_1(TreeNode root) {
if(root==null)
return;
Stack<TreeNode> stack=new Stack<TreeNode>();
stack.push(root);
while(!stack.isEmpty()){
TreeNode node=stack.pop();
if(node.right!=null)
stack.push(node.right);
if(node.left!=null)
stack.push(node.left);
if(!stack.isEmpty())
node.right=stack.peek();
node.left=null;
}
}
/*
* 低效率解法
*/
public void flatten_2(TreeNode root) {
if(root==null)
return;
List<TreeNode> list=new ArrayList<TreeNode>();
Stack<TreeNode> stack=new Stack<TreeNode>();
stack.push(root);
TreeNode node=null;
while(!stack.isEmpty()||node!=null){
if(node==null){
node=stack.pop();
node=node.right;
}else{
stack.push(node);
list.add(node);
node=node.left;
}
}
TreeNode node1=null;
TreeNode node2=null;
for(int i=0;i<list.size()-1;i++){
node1=list.get(i);
node2=list.get(i+1);
node1.left=null;
node1.right=node2;
}
node2.left=null;node2.right=null;
}
}
相关文章推荐
- [leetcode]145. Binary Tree Postorder Traversal@Java解题报告
- 【LeetCode】Single Number 解题报告(Java & Python)
- [leetcode]142. Linked List Cycle II@Java解题报告
- [leetcode]133. Clone Graph@Java解题报告
- Add Binary | leetcode 67 【Java解题报告】
- Climbing Stairs | leetcode 70 【Java解题报告】
- Move Zeroes | leetcode 283 【Java解题报告】
- Ugly Number | leetcode 263 【Java解题报告】
- [leetcode]19. Remove Nth Node From End of List@Java解题报告
- [leetcode]46. Permutations@Java解题报告
- 【LeetCode】Reverse Linked List 解题报告(Python & java)
- [leetcode]47. Permutations II@Java解题报告
- [leetcode]107. Binary Tree Level Order Traversal II@Java解题报告
- [leetcode]151. Reverse Words in a String@Java解题报告
- [leetcode]50. Pow(x, n)@Java解题报告
- [leetcode]68. Text Justification@Java解题报告
- [leetcode]103. Binary Tree Zigzag Level Order Traversal@Java解题报告
- [leetcode]105. Construct Binary Tree from Preorder and Inorder Traversal@Java解题报告
- [leetcode]110. Balanced Binary Tree@Java解题报告
- [leetcode]125. Valid Palindrome@Java解题报告