leetcode897:遞增順序查找樹



一、題目

網址遞增順序查找樹

難度:簡單。

給定一個樹,按中序遍歷重新排列樹,使樹中最左邊的結點現在是樹的根,並且每個結點沒有左子結點,只有一個右子結點。

示例:

輸入:[5,3,6,2,4,null,8,1,null,null,null,7,9]

       5
      / \
    3    6
   / \    \
  2   4    8
 /        / \ 
1        7   9

輸出:[1,null,2,null,3,null,4,null,5,null,6,null,7,null,8,null,9]

 1
  \
   2
    \
     3
      \
       4
        \
         5
          \
           6
            \
             7
              \
               8
                \
                 9  

提示:

給定樹中的結點數介於 1 和 100 之間。
每個結點都有一個從 0 到 1000 範圍內的唯一整數值。

二、程序

思路:先按中序對樹進行遍歷,將結果存爲數組,然後再構造符合題目的樹。

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    vector<int> InoRes;
    
    void inOrder(TreeNode* root)
    {
        if(root==NULL) return;
        inOrder(root->left);
        InoRes.push_back(root->val);
        inOrder(root->right);
    }
   
    TreeNode* increasingBST(TreeNode* root) {
        inOrder(root);
        
        TreeNode* cur=new TreeNode(InoRes[0]);
        TreeNode* r=cur;
        for(int i=1;i<InoRes.size();i++)
        {
            cur->right=new TreeNode(InoRes[i]);
            cur=cur->right;
        } 

        return r;

    }
};

結果:
在這裏插入圖片描述

發佈了90 篇原創文章 · 獲贊 37 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章