Problem Description:
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.
思路一,按照題意從根節點開始,如果當前節點有左孩子,就將它的左孩子添加到自己和右孩子之間,這裡每次需要找到左孩子最右邊的節點,連接到當前右孩子。然後依次往右處理自己的右孩子,直到右孩子為空。具體代碼如下:/** * Definition for binary tree * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: void flatten(TreeNode *root) { if(root==NULL) return; while (root != NULL) { if (root->left != NULL) { TreeNode *p = root->left; while (p->right != NULL) //找到左孩子的最右邊節點 { p = p->right; } p->right = root->right; root->right = root->left; root->left = NULL; } root = root->right; } } };
/** * Definition for binary tree * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: TreeNode *pre=NULL; void flatten(TreeNode *root) { if(root==NULL) return; TreeNode *lastright=root->right;//記錄當前節點的右子樹 if(pre) { pre->left=NULL; pre->right=root; } pre=root; flatten(root->left); flatten(lastright); } };