[剑指オファー] JT26 ---二分探索木と二重リンクリスト(数日間熟考した後、それはかなり抽象的な質問です)

トピックは次のとおりです

二分探索木を入力し、二分探索木をソートされた二重リンクリストに変換します。新しいノードを作成できないようにする必要がありますが、調整できるのはツリー内のノードポインターのポイントだけです。
簡単な質問ですが、とても痛いです。

アイデアとコードは次のとおりです

私の個人的な理解は比較的表面的なもので、中次走査
です。再帰構造の分析後、更新します。
結局、この質問は数日間スタックしているので、最初に書き留めてください。

/*
struct TreeNode {
	int val;
	struct TreeNode *left;
	struct TreeNode *right;
	TreeNode(int x) :
			val(x), left(NULL), right(NULL) {
	}
};*/
class Solution {
    
    
public:
    TreeNode* Convert(TreeNode* pRootOfTree)
    {
    
    
        if(pRootOfTree == nullptr) return nullptr;
        TreeNode* pre = nullptr;    
        convertHelper(pRootOfTree, pre);        
        TreeNode* res = pRootOfTree;
        while(res ->left)
            res = res ->left;
        return res;
    }  
    void convertHelper(TreeNode* cur, TreeNode*& pre)
    {
    
    
        if(cur == nullptr) return;        
        convertHelper(cur ->left, pre);    
        cur ->left = pre;
        if(pre) pre ->right = cur;
        pre = cur;      
        convertHelper(cur ->right, pre);
    }
};

ここに画像の説明を挿入します

おすすめ

転載: blog.csdn.net/qq_42136832/article/details/114794645