代码随想录刷题——二叉树篇(二十一)

108. 将有序数组转换为二叉搜索树
递归法:

cpp 复制代码
class Solution {
private:
	TreeNode* traversal(vector<int>& nums,int left,int right){
		if(left>right) return NULL;
		int mid=left+(right-left)/2;
		TreeNode* node=new TreeNode(nums[mid]);
		node->left=traversal(nums,left,mid-1);
		node->right=traversal(nums,mid+1,right);
		return node;
	}
public:
    TreeNode* sortedArrayToBST(vector<int>& nums) {
        if(nums.size()==0) return NULL;
        TreeNode* root=traversal(nums,0,nums.size()-1);
        return root;
    }
};

迭代法:

cpp 复制代码
class Solution{
public:
	TreeNode* sortedArrayToBST(vector<int>& nums){
		if(nums.size()==0) return NULL;
		queue<TreeNode*> quenode;
		queue<int> queleft;
		queue<int> queright;
		TreeNode* root=new TreeNode(0);
		quenode.push(root);
		queleft.push(0);
		queright.push(nums.size()-1);
		while(!quenode.empty()){
			TreeNode* node=quenode.front();
			quenode.pop();
			int left=queleft.front();
			queleft.pop();
			int right=queright.front();
			queright.pop();
			int mid=left+(right-left)/2;
			node->val=nums[mid];
			if(left<=mid-1){
				TreeNode* ln=new TreeNode(0);
				node->left=ln;
				quenode.push(ln);
				queleft.push(left);
				queright.push(mid-1);
			}
			if(right>=mid+1){
				TreeNode* rn=new TreeNode(0);
				node->right=rn;
				quenode.push(rn);
				queleft.push(mid+1);
				queright.push(right);
			}
		}
		return root;
	}
};

538. 把二叉搜索树转换为累加树
递归法:

cpp 复制代码
class Solution{
private:
	int pre=0;
	TreeNode* traversal(TreeNode* root){
		if(!root) return root;
		root->right=traversal(root->right);
		root->val+=pre;
		pre=root->val;
		root->left=traversal(root->left);
		return root;
	}
public:
	TreeNode* convertBST(TreeNode* root){
		root = traversal(root);
		return root;
	}
};

迭代法:

cpp 复制代码
class Solution{
public:
	TreeNode* convertBST(TreeNode* root){
		if(!root) return NULL;
		stack<TreeNode*> stk;
		TreeNode* cur=root;
		int pre=0;
		while(cur||!stk.empty()){
			if(cur){
				stk.push(cur);
				cur=cur->right;
			}else{
				cur=stk.top();
				stk.pop();
				cur->val+=pre;
				pre=cur->val;
				cur=cur->left;
			}
		}
		return root;
	}
};

其他:

(1)递归法还是注意维护好开闭区间 ,以及中间的节点被用掉后 ,mid所指向的数据已经被使用,左侧区间 的右边界下标为mid-1,右侧区间的左边界下标为mid+1

(2)迭代法可以用多个不同类型的栈或者队列 来存储所需要的多种参数/变量 ,只需要出栈/出队 时需要的一套参数/变量是对应的就行

(3)通常来说,树的结构 如果有变动 节点、 节点),就用有返回值的递归 ,如果树的结构并没有变动 (也就是只变了某些节点的值/ 节点、 节点),就使用没有返回值的递归

相关推荐
!停2 小时前
数据结构排序算法—插入排序
数据结构·算法·排序算法
谁不学习揍谁!2 小时前
基于python大数据机器学习旅游数据分析可视化推荐系统(完整系统+开发文档+部署教程+文档等资料)
大数据·python·算法·机器学习·数据分析·旅游·数据可视化
yyjtx2 小时前
DHU上机打卡D28
开发语言·c++·算法
programhelp_2 小时前
Snowflake OA 2026真题解析|3道Hard Coding全拆解,附DP+双指针实战思路
算法
专注VB编程开发20年2 小时前
C#,VB.NET GPU计算和调试
算法·gpu
Protein_zmm2 小时前
【算法基础】位运算、离散化、区间合并
java·算法·spring
WZ188104638692 小时前
LeetCode第54题
算法·leetcode
俩娃妈教编程2 小时前
2025 年 06 月 三级真题(1)--分糖果
c++·算法·gesp真题
tankeven2 小时前
HJ97 记负均正
c++·算法