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

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

相关推荐
颜酱12 小时前
最小生成树(MST)核心原理 + Kruskal & Prim 算法
javascript·后端·算法
啊哦呃咦唔鱼12 小时前
LeetCode hot100-3 无重复字符的最长子串
算法·leetcode·职场和发展
phltxy13 小时前
算法刷题|模拟思想高频题全解(Java版)
java·开发语言·算法
宵时待雨13 小时前
C++笔记归纳10:继承
开发语言·数据结构·c++·笔记·算法
田梓燊13 小时前
最长的连续序列到底怎么写
算法·哈希算法·散列表
smchaopiao13 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
一叶落43813 小时前
LeetCode 21. 合并两个有序链表(C语言详解 | 链表经典题)
c语言·数据结构·c++·算法·leetcode·链表
阿里嘎多哈基米13 小时前
速通Hot100-Day04——哈希
数据结构·算法·leetcode·哈希算法·散列表
飞天狗11114 小时前
最短路算法
算法
汉克老师14 小时前
GESPC++考试五级语法知识(二、埃氏筛与线性筛)课后习题
算法·线性筛·素数·gesp5级·gesp五级·埃氏筛·筛法