1. 程式人生 > >LeetCode 114. 二叉樹展開為鏈表(Flatten Binary Tree to Linked List)

LeetCode 114. 二叉樹展開為鏈表(Flatten Binary Tree to Linked List)

tree binary ont 基本思想 oot public ike 返回 上一個

題目描述

給定一個二叉樹,原地將它展開為鏈表。

例如,給定二叉樹

    1
   /   2   5
 / \   3   4   6

將其展開為:

1
   2
       3
           4
               5
                   6

解題思路

二叉樹轉化為鏈表的基本思想是:對於左孩子轉化為右孩子;對於右孩子,拼接到根結點左子樹最後一個節點作為右孩子。所以在自上而下轉化時,對於每個節點要先保存其右孩子,然後記錄轉為鏈表後本子樹的最後一個節點並返回給上一個根節點。

代碼

 1 /**
 2  * Definition for a binary tree node.
3 * struct TreeNode { 4 * int val; 5 * TreeNode *left; 6 * TreeNode *right; 7 * TreeNode(int x) : val(x), left(NULL), right(NULL) {} 8 * }; 9 */ 10 class Solution { 11 public: 12 void flatten(TreeNode* root) { 13 if(root) flat(root); 14 } 15 TreeNode* flat(TreeNode* root){
16 if(root->left == NULL && root->right == NULL) return root; 17 TreeNode* right = root->right; 18 TreeNode* last = NULL; 19 if(root->left){ 20 root->right = root->left; 21 root->left = NULL; 22 last = flat(root->right);
23 last->right = right; 24 } 25 if(right) return flat(right); 26 return last; 27 } 28 };

LeetCode 114. 二叉樹展開為鏈表(Flatten Binary Tree to Linked List)