题目链接https://leetcode-cn.com/problems/increasing-order-search-tree/

解题代码
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
TreeNode* increasingBST(TreeNode* root) {
if(root==NULL){
return nullptr;
}
vector<int> nums;
inOrder(root, nums);
int size = nums.size();
TreeNode* root1 = new TreeNode(nums[0]);
TreeNode* ans = root1;
for(int i=1; i<size; i++){
TreeNode* temp = new TreeNode(nums[i]);
root1->right = temp;
root1 = temp;
}
return ans;
}
void inOrder(TreeNode* root, vector<int>& nums){
if(root==NULL){
return;
}
if(root->left!=NULL){
inOrder(root->left, nums);
}
nums.push_back(root->val);
if(root->right!=NULL){
inOrder(root->right, nums);
}
}
};
运行结果

该博客详细介绍了如何使用C++解决LeetCode上的一个问题——将一个二叉搜索树转换为一个排序的链表。通过中序遍历收集节点值,然后重新构建一棵新的有序二叉搜索树。代码中包含两个主要函数,一个是`increasingBST`用于转换树,另一个是`inOrder`进行中序遍历。这种方法巧妙地利用了二叉搜索树的性质,使得结果树的所有节点值都按升序排列。
537

被折叠的 条评论
为什么被折叠?



