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

如何建设游戏平台网站爱站长

如何建设游戏平台网站,爱站长,wordpress中文cms主题模板下载,网站排名如何上升654.最大二叉树 注意类似用数组构造二叉树的题目,每次分隔尽量不要定义新的数组,而是通过下标索引直接在原数组上操作,这样可以节约时间和空间上的开销。 题目链接/文章讲解:代码随想录 lass Solution { private:// 在左闭右开…

654.最大二叉树

注意类似用数组构造二叉树的题目,每次分隔尽量不要定义新的数组,而是通过下标索引直接在原数组上操作,这样可以节约时间和空间上的开销。

题目链接/文章讲解:代码随想录

lass Solution {
private:// 在左闭右开区间[left, right),构造二叉树TreeNode* traversal(vector<int>& nums, int left, int right) {if (left >= right) return nullptr;// 分割点下标:maxValueIndexint maxValueIndex = left;for (int i = left + 1; i < right; ++i) {if (nums[i] > nums[maxValueIndex]) maxValueIndex = i;}TreeNode* root = new TreeNode(nums[maxValueIndex]);// 左闭右开:[left, maxValueIndex)root->left = traversal(nums, left, maxValueIndex);// 左闭右开:[maxValueIndex + 1, right)root->right = traversal(nums, maxValueIndex + 1, right);return root;}
public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {return traversal(nums, 0, nums.size());}
};

617.合并二叉树

优先掌握递归。

代码随想录

递归法

class Solution {
public:TreeNode* mergeTrees(TreeNode* t1, TreeNode* t2) {if (t1 == NULL) return t2;if (t2 == NULL) return t1;// 重新定义新的节点,不修改原有两个树的结构TreeNode* root = new TreeNode(0);root->val = t1->val + t2->val;root->left = mergeTrees(t1->left, t2->left);root->right = mergeTrees(t1->right, t2->right);return root;}
};

迭代法

class Solution {
public:TreeNode* mergeTrees(TreeNode* t1, TreeNode* t2) {if (t1 == NULL) return t2;if (t2 == NULL) return t1;queue<TreeNode*> que;que.push(t1);que.push(t2);while(!que.empty()) {TreeNode* node1 = que.front(); que.pop();TreeNode* node2 = que.front(); que.pop();// 此时两个节点一定不为空,val相加node1->val += node2->val;// 如果两棵树左节点都不为空,加入队列if (node1->left != NULL && node2->left != NULL) {que.push(node1->left);que.push(node2->left);}// 如果两棵树右节点都不为空,加入队列if (node1->right != NULL && node2->right != NULL) {que.push(node1->right);que.push(node2->right);}// 当t1的左节点 为空 t2左节点不为空,就赋值过去if (node1->left == NULL && node2->left != NULL) {node1->left = node2->left;}// 当t1的右节点 为空 t2右节点不为空,就赋值过去if (node1->right == NULL && node2->right != NULL) {node1->right = node2->right;}}return t1;}
};

700.二叉搜索树中的搜索

递归和迭代都掌握

二叉搜索树的特点是根节点比左孩子节点要大,比右孩子节点要小。

代码随想录

递归法:注意遍历左右子树的时候要返回函数,如果左右子树都遍历不到的时候,就返回空

class Solution {
public:TreeNode* searchBST(TreeNode* root, int val) {if (root == NULL || root->val == val) return root;if (root->val > val) return searchBST(root->left, val);if (root->val < val) return searchBST(root->right, val);return NULL;}
};
class Solution {
public:TreeNode* searchBST(TreeNode* root, int val) {while (root != NULL) {if (root->val > val) root = root->left;else if (root->val < val) root = root->right;else return root;}return NULL;}
};

98.验证二叉搜索树

遇到 搜索树,一定想着中序遍历,这样才能利用上特性。

注意根节点要比所有左子树的所有节点都要小,要比所有右子树的节点都要大。

方法一:maxValue来记录前一个节点的数值,如果前一个节点的数值(按照中序的遍历顺序,数组的值应该是递增的(如果是平衡二叉树的话),否则就不是平衡二叉树)
方法二:用pre记录前一个节点,当前节点和pre进行比较,pre进行更新。

class Solution {
public:TreeNode* pre = NULL; // 用来记录前一个节点bool isValidBST(TreeNode* root) {if (root == NULL) return true;bool left = isValidBST(root->left);if (pre != NULL && pre->val >= root->val) return false;pre = root; // 记录前一个节点bool right = isValidBST(root->right);return left && right;}
};

也可以用迭代法,只用增加一个指针指向前一个节点和判断什么时候返回fasle以及更新前一个指针的。
注意:while中是两个条件是或的情况!!!!

代码随想录

class Solution {
public:bool isValidBST(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur = root;TreeNode* pre = NULL; // 记录前一个节点while (cur != NULL || !st.empty()) {if (cur != NULL) {st.push(cur);cur = cur->left;                // 左} else {cur = st.top();                 // 中st.pop();if (pre != NULL && cur->val <= pre->val)return false;pre = cur; //保存前一个访问的结点cur = cur->right;               // 右}}return true;}
};
http://www.ritt.cn/news/25291.html

相关文章:

  • 网站维护员免费浏览外国网站的软件
  • 做家电选招标采购哪一个网站好提高工作效率的软件
  • 温州营销网站制作联系电话十大跨界营销案例
  • 做app的模板下载网站有哪些网络营销管理办法
  • 庞各庄网站建设seo排名优化教程
  • 网站漂浮特效怎么做关联词有哪些小学
  • wordpress添加论坛杭州网站seo外包
  • shopnc本地生活o2o网站系统百度客户服务中心
  • wordpress去掉更新提示四川seo哪里有
  • 北京企业网站推广网上怎么找人去推广广告
  • 网站开发 ssh 菜鸟优化网站页面
  • 网站建设及服务合同书引擎搜索是什么意思
  • 可信网站认证必须做吧免费二级域名申请网站
  • net网站开发参考文献站长域名查询
  • 网站建设规划公司地址磁力兔子
  • 怎么做网站数据库近期重大新闻
  • 做b2b2c商城网站杭州网站推广找哪家
  • 天津微网站建设百度app官方下载
  • 网站建设方案.docsemir是什么牌子
  • 律师个人 网站做优化百度文库个人登录
  • 无锡做食品网站的公司哪家好四川seo
  • 知名网站建设公司免费代码网站
  • 做自己的网站要钱么网络推广服务外包
  • 珠海网络公司排名搜索引擎优化seo应用
  • 学做电商的网站有哪些企业seo网络推广
  • 自己建设网站的利弊免费访问国外网站的app
  • 公司名字大全推荐单页网站排名优化
  • 站长网站被跳转怎么办西安今日头条新闻消息
  • 网络规划设计师考纲教材改版新旧对比免费seo网站的工具
  • wordpress修改文章时间股票发行ipo和seo是什么意思