オファーの26番目の質問
トピックは次のとおりです
二分探索木を入力し、二分探索木をソートされた二重リンクリストに変換します。新しいノードを作成できないようにする必要がありますが、調整できるのはツリー内のノードポインターのポイントだけです。
簡単な質問ですが、とても痛いです。
アイデアとコードは次のとおりです
私の個人的な理解は比較的表面的なもので、中次走査
です。再帰構造の分析後、更新します。
結局、この質問は数日間スタックしているので、最初に書き留めてください。
/*
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);
}
};