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

新浦网站制作什么网站可以做报名系统

新浦网站制作,什么网站可以做报名系统,wordpress 4.5.3 主题,规模以上工业企业利润总额代码随想录算法训练营65期第17天 本文中使用到一些代码随想录里面的图片或者链接,在这里致敬程序员Carl 654.最大二叉树 又是构造二叉树,昨天大家刚刚做完 中序后序确定二叉树,今天做这个 应该会容易一些, 先看视频,好…

代码随想录算法训练营65期第17天

本文中使用到一些代码随想录里面的图片或者链接,在这里致敬程序员Carl

654.最大二叉树
又是构造二叉树,昨天大家刚刚做完 中序后序确定二叉树,今天做这个 应该会容易一些, 先看视频,好好体会一下 为什么构造二叉树都是 前序遍历
题目链接/文章讲解:代码随想录
视频讲解

题目的意思是:给定一个不含重复元素的整数数组。
一个以此数组构建的最大二叉树定义如下:
二叉树的根是数组中的最大元素。
左子树是通过数组中最大值左边部分构造出的最大二叉树。
右子树是通过数组中最大值右边部分构造出的最大二叉树。
通过给定的数组构建最大二叉树,并且输出这个树的根节点。
示例:
在这里插入图片描述
非常关键的一句话是:构造树一般采用的是前序遍历,因为先构造中间节点,然后递归构造左子树和右子树。
接下来递归三部曲:
①、确定递归函数的参数和返回值
参数传入的是存放元素的数组,返回该数组构造的二叉树的头结点,返回类型是指向节点的指针。
代码如下:

TreeNode* constructMaximumBinaryTree(vector<int>& nums)

②、确定终止条件
题目中说了输入的数组大小一定是大于等于1的,所以我们不用考虑小于1的情况,那么当递归遍历的时候,如果传入的数组大小为1,说明遍历到了叶子节点了。(其实不是很明白这里说遍历到叶子结点的含义)。。那么应该定义一个新的节点,并把这个数组的数值赋给新的节点,然后返回这个节点。 这表示一个数组大小是1的时候,构造了一个新的节点,并返回。代码如下:

TreeNode* node = new TreeNode(0);
if (nums.size() == 1) {node->val = nums[0];return node;
}

③、确定单层递归的逻辑
1、先要找到数组中最大的值和对应的下标, 最大的值构造根节点,下标用来下一步分割数组。代码如下:

int maxValue = 0;
int maxValueIndex = 0;
for (int i = 0; i < nums.size(); i++) {if (nums[i] > maxValue) {maxValue = nums[i];maxValueIndex = i;}
}
TreeNode* node = new TreeNode(0);
node->val = maxValue;

2、最大值所在的下标左区间 构造左子树
这里要判断maxValueIndex > 0,因为要保证左区间至少有一个数值。

if (maxValueIndex > 0) {vector<int> newVec(nums.begin(), nums.begin() + maxValueIndex);node->left = constructMaximumBinaryTree(newVec);
}

3、最大值所在的下标右区间 构造右子树
判断maxValueIndex < (nums.size() - 1),确保右区间至少有一个数值。代码如下:

if (maxValueIndex < (nums.size() - 1)) {vector<int> newVec(nums.begin() + maxValueIndex + 1, nums.end());node->right = constructMaximumBinaryTree(newVec);
}

完整代码如下:

class Solution {
public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {TreeNode* node = new TreeNode(0);if (nums.size() == 1) {node->val = nums[0];return node;}// 找到数组中最大的值和对应的下标int maxValue = 0;int maxValueIndex = 0;for (int i = 0; i < nums.size(); i++) {if (nums[i] > maxValue) {maxValue = nums[i];maxValueIndex = i;}}node->val = maxValue;// 最大值所在的下标左区间 构造左子树if (maxValueIndex > 0) {vector<int> newVec(nums.begin(), nums.begin() + maxValueIndex);node->left = constructMaximumBinaryTree(newVec);}// 最大值所在的下标右区间 构造右子树if (maxValueIndex < (nums.size() - 1)) {vector<int> newVec(nums.begin() + maxValueIndex + 1, nums.end());node->right = constructMaximumBinaryTree(newVec);}return node;}
};

优化后的代码:

class 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.合并二叉树
这次是一起操作两个二叉树了, 估计大家也没一起操作过两个二叉树,也不知道该如何一起操作,可以看视频先理解一下。 优先掌握递归。
跳转链接: 代码随想录,视频讲解

这道题目意思:给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠。你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否则不为 NULL 的节点将直接作为新二叉树的节点
代码如下:

class Solution {
public:TreeNode* mergeTrees(TreeNode* t1, TreeNode* t2) {if (t1 == NULL) return t2; // 如果t1为空,合并之后就应该是t2if (t2 == NULL) return t1; // 如果t2为空,合并之后就应该是t1// 修改了t1的数值和结构t1->val += t2->val;                             // 中t1->left = mergeTrees(t1->left, t2->left);      // 左t1->right = mergeTrees(t1->right, t2->right);   // 右return t1;}
};

700.二叉搜索树中的搜索
递归和迭代 都可以掌握以下,因为本题比较简单, 了解一下 二叉搜索树的特性
题目链接:代码随想录,视频讲解

题目意思:给定二叉搜索树(BST)的根节点和一个值。 你需要在BST中找到节点值等于给定值的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 NULL。
在这里插入图片描述在上述示例中,如果要找的值是 5,但因为没有节点值为 5,我们应该返回 NULL。
整体代码如下:

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

98.验证二叉搜索树
遇到 搜索树,一定想着中序遍历,这样才能利用上特性。但本题是有陷阱的,可以自己先做一做,然后在看题解,看看自己是不是掉陷阱里了。这样理解的更深刻。
题目链接:代码随想录,视频讲解

题目意思: 给定一个二叉树,判断其是否是一个有效的二叉搜索树。
假设一个二叉搜索树具有如下特征:
节点的左子树只包含小于当前节点的数。
节点的右子树只包含大于当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树
在这里插入图片描述
整体的代码如下:

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;}
};
http://www.dtcms.com/wzjs/615140.html

相关文章:

  • 注册网站什么要求白银市住房和城乡建设厅网站首页
  • 网站优化师招聘wordpress输入密码访问
  • 凡科网站的ftp大网站成本
  • 什么是网站代理网页美工设计中使用的主要软件是
  • 营销型网站建设哪里济南兴田德润优惠吗朝阳网站建设开发
  • 微信网站建设流程深圳专业返利网站建设
  • 网站备案号没有-1安装app软件
  • 有专门做消除网站上对公司不利的纸箱 技术支持 东莞网站建设
  • 一个手机网站兰州seo优化公司
  • 网络公司 网站建设石家庄北国商城
  • 福清营销型网站建设方案网站公司倒闭
  • 最好的扁平化网站幽默软文经典案例300
  • 流行网站设计wordpress cdn 阿里
  • 用模板建商城购物网站网上接网站开发不给钱怎么办
  • 淘宝美工做兼职的网站定制衣柜十大品牌排名
  • 上海 网站开发 外包淘宝网站建设的详细策划
  • 网站设计与制作专业网页代理app
  • 如何做网站标头手机企业网站程序
  • 临清网站建设服务wordpress 公众号 采集
  • 新建的网站只能用临时域名打开如何在网站上做网页链接
  • 商丘购物网站开发设计哈尔滨网站建设1元钱
  • 网站建设人员安排如何快速搭建个人网站
  • 行业网站导航如何自己做众筹网站
  • 商务网站的特点优化网站建设哪家专业
  • 郑州网站建设伟置设计方案英文
  • 南昌网站seo外包濮阳手机网站建设
  • 杭州盘石做网站专业吗openshift 安装 wordpress
  • 简述网页与网站的区别视频网站用什么cms
  • 如何建设一个专业的网站怎么做精准引流推广
  • 全能网站建设湖南手机版建站系统哪个好