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

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

相关推荐
SUNNY_SHUN4 分钟前
VLM走进农田:AgriChat覆盖3000+作物品类,607K农业视觉问答基准开源
论文阅读·人工智能·算法·开源
黎阳之光6 分钟前
视频孪生赋能车路云一体化,领跑智慧高速新征程
人工智能·算法·安全·数字孪生
Darkwanderor29 分钟前
高精度计算——基础模板整理
c++·算法·高精度计算
普马萨特43 分钟前
基站 / WiFi 粗略位置对 A-GNSS 的影响
网络·人工智能·算法
py有趣1 小时前
力扣热门100题之接雨水
算法·leetcode
mmz12071 小时前
深度优先搜索DFS(c++)
c++·算法·深度优先
汀、人工智能2 小时前
[特殊字符] 第103课:单词搜索II
数据结构·算法·均值算法·前缀树·trie·单词搜索ii
wanderist.3 小时前
算法模板-字符串
数据结构·算法·哈希算法
xiaoye-duck3 小时前
《算法题讲解指南:动态规划算法--子序列问题》--29.最长递增子序列的个数,30.最长数对链,31.最长定差子序列
c++·算法·动态规划
Yzzz-F3 小时前
Problem - 2180D - Codeforces
算法