当前位置: 首页 > news >正文

辽阳网站建设学校东营建设信息网站电话

辽阳网站建设学校,东营建设信息网站电话,停车场收费标准,wordpress自动推送百度669 修剪二叉搜索树 给定一个二叉搜索树,同时给定最小边界L 和最大边界 R。通过修剪二叉搜索树,使得所有节点的值在[L, R]中 (R>L) 。你可能需要改变树的根节点,所以结果应当返回修剪好的二叉搜索树的新的根节点。 class Solution { pub…

669 修剪二叉搜索树

给定一个二叉搜索树,同时给定最小边界L 和最大边界 R。通过修剪二叉搜索树,使得所有节点的值在[L, R]中 (R>=L) 。你可能需要改变树的根节点,所以结果应当返回修剪好的二叉搜索树的新的根节点。

class Solution {
public:TreeNode* trimBST(TreeNode* root, int low, int high) {if(root == nullptr) return root; //如果是空节点直接返回//如果结点小于最小结点,这个肯定要删,此时看一下右孩子们小不小if(root->val < low) return trimBST(root->right, low, high);//如果结点大于最大结点,这个肯定要删,此时看一下左孩子们大不大if(root->val >high) return trimBST(root->left, low, high);//接收返回值并且一直递归root->left = trimBST(root->left,low, high);root->right = trimBST(root->right, low, high);return root;}
};
class Solution {
public:TreeNode* trimBST(TreeNode* root, int L, int R) {if (!root) return nullptr;// 处理头结点,让root移动到[L, R] 范围内,注意是左闭右闭while (root != nullptr && (root->val < L || root->val > R)) {if (root->val < L) root = root->right; // 小于L往右走else root = root->left; // 大于R往左走}TreeNode *cur = root;// 此时root已经在[L, R] 范围内,处理左孩子元素小于L的情况while (cur != nullptr) {while (cur->left && cur->left->val < L) {cur->left = cur->left->right;}cur = cur->left;}cur = root;// 此时root已经在[L, R] 范围内,处理右孩子大于R的情况while (cur != nullptr) {while (cur->right && cur->right->val > R) {cur->right = cur->right->left;}cur = cur->right;}return root;}
};

108.将有序数组转换为二叉搜索树

将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树。

本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1。

class Solution {
private:TreeNode* traversal(vector<int>& nums, int left, int right) {if(right < left) return nullptr;//为了保证平衡,新创建的一定是中间头结点int middle = (left+right)/2;TreeNode* root = new TreeNode(nums[middle]);root->left = traversal(nums,left,middle-1);root->right = traversal(nums, middle+1,right);return root;}
public:TreeNode* sortedArrayToBST(vector<int>& nums) {return traversal(nums,0,nums.size()-1);}
};

迭代法比较复杂,这里先记录一下

class Solution {
public:TreeNode* sortedArrayToBST(vector<int>& nums) {if (nums.size() == 0) return nullptr;TreeNode* root = new TreeNode(0);   // 初始根节点queue<TreeNode*> nodeQue;           // 放遍历的节点queue<int> leftQue;                 // 保存左区间下标queue<int> rightQue;                // 保存右区间下标nodeQue.push(root);                 // 根节点入队列leftQue.push(0);                    // 0为左区间下标初始位置rightQue.push(nums.size() - 1);     // nums.size() - 1为右区间下标初始位置while (!nodeQue.empty()) {TreeNode* curNode = nodeQue.front();nodeQue.pop();int left = leftQue.front(); leftQue.pop();int right = rightQue.front(); rightQue.pop();int mid = left + ((right - left) / 2);curNode->val = nums[mid];       // 将mid对应的元素给中间节点if (left <= mid - 1) {          // 处理左区间curNode->left = new TreeNode(0);nodeQue.push(curNode->left);leftQue.push(left);rightQue.push(mid - 1);}if (right >= mid + 1) {         // 处理右区间curNode->right = new TreeNode(0);nodeQue.push(curNode->right);leftQue.push(mid + 1);rightQue.push(right);}}return root;}
};

 538 二叉搜索树转换为累加树

class Solution {
private:int pre = 0; // 记录前一个节点的数值void traversal(TreeNode* cur) { // 右中左遍历if (cur == NULL) return;traversal(cur->right);cur->val += pre;pre = cur->val;traversal(cur->left);}
public:TreeNode* convertBST(TreeNode* root) {pre = 0;traversal(root);return root;}
};
class Solution {
private:int pre; // 记录前一个节点的数值void traversal(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur = root;while (cur != NULL || !st.empty()) {if (cur != NULL) {st.push(cur);cur = cur->right;   // 右} else {cur = st.top();     // 中st.pop();cur->val += pre;pre = cur->val;cur = cur->left;    // 左}}}
public:TreeNode* convertBST(TreeNode* root) {pre = 0;traversal(root);return root;}
};

 二叉树,就此完结!

http://www.yayakq.cn/news/795615/

相关文章:

  • 个人小程序制作流程网站关键词优化快速排名
  • 安防网站源码建设艺术网站需要多少钱
  • 商业网站开发需求宁波网站建设哪家强
  • 专业网站建设明细报价表室内设计网站图片
  • seo的定义是什么阳江网站关键字优化
  • 哈尔滨建站模板厂家酒水销售网站模板
  • 网站如何转做app网页制作多少分
  • python 兼职网站开发百度seo营销公司
  • 做网站遇到的困难总结企业网络搭建与应用
  • 怎么查看网站有没有做301软件开发教程自学教程
  • 水利建设专项收入在什么网站上申报网站做商业计划书吗
  • 揭秘低价网站建设危害重庆建设工程招标信息网
  • 购物网站建设前的市场分析广州网站建设大公司排名
  • 泰兴网站建设佛山网站建设公司哪家性价比高
  • ps做好切片后怎么做网站推广计划是什么
  • 广州黄埔区建设局网站局百度联盟广告收益
  • 门户网站开发 系统介绍北京人事考试网
  • asp网站开发 知识永安城乡建设局网站
  • 什么是建设企业网站梅州市建设培训中心网站
  • 模板网站 知乎室内设计师网站十大网站
  • Hdi做指数网站网站搭建 主机推荐
  • 长春火车站到长春机场大巴时刻表seo 深圳
  • 网站制作需要什么软件网络安全十大公司
  • 韩国购物网站做企业网站通常哪找素材
  • 沈阳网站建设技术公司排名网站关键词是什么意思
  • 一般的网站都是用什么系统做的制作成长纪念册
  • 网站建设与维护工作待遇做外贸比较好得网站
  • 赣州人才网站路由器做网站主机要备案吗
  • 谷歌网站英文新河官网
  • 建网站科技公司长沙招聘信息2022