代码随想录算法训练营第36期DAY22

server/2024/9/22 23:22:47/

DAY22

654最大二叉树

自己做的时候忽略了:nums.length>=1的题给条件。所以每次递归都要判断是否size()>=1,不要空的。

  1. /**
  2.  * Definition for a binary tree node.
  3.  * struct TreeNode {
  4.  *     int val;
  5.  *     TreeNode *left;
  6.  *     TreeNode *right;
  7.  *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8.  *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9.  *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10.  * };
  11.  */
  12. class Solution {
  13. public:
  14.     TreeNode* constructMaximumBinaryTree(vector<int>& nums) {
  15.         TreeNode* node=new TreeNode(0);
  16.         if(nums.size()==1) {
  17.             node->val=nums[0];
  18.             return node;
  19.         }
  20.         int index=0;
  21.         for(int i=1;i<nums.size();i++)
  22.         {
  23.             if(nums[index]<nums[i]) index=i;
  24.         }
  25.         node->val=nums[index];
  26.         if(index>0){
  27.             vector<intln(nums.begin(),nums.begin()+index);
  28.             node->left=constructMaximumBinaryTree(ln);
  29.         }
  30.         if(index<nums.size()-1){
  31.             vector<intrn(nums.begin()+index+1,nums.end());
  32.             node->right=constructMaximumBinaryTree(rn);
  33.         }
  34.         return node;
  35.     }
  36. };

617合并二叉树

递归之前,先弄明白遍历顺序很重要:

  1. /**
  2.  * Definition for a binary tree node.
  3.  * struct TreeNode {
  4.  *     int val;
  5.  *     TreeNode *left;
  6.  *     TreeNode *right;
  7.  *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8.  *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9.  *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10.  * };
  11.  */
  12. class Solution {
  13. public:
  14.     TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {
  15.         if(root1==nullptr) return root2;
  16.         if(root2==nullptr) return root1;
  17.         root1->val+=root2->val;
  18.         root1->left=mergeTrees(root1->left,root2->left);
  19.         root1->right=mergeTrees(root1->right,root2->right);
  20.         return root1;
  21.     }
  22. };

700二叉搜索树中的搜索

先写迭代法,返璞归真咯:

  1. /**
  2.  * Definition for a binary tree node.
  3.  * struct TreeNode {
  4.  *     int val;
  5.  *     TreeNode *left;
  6.  *     TreeNode *right;
  7.  *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8.  *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9.  *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10.  * };
  11.  */
  12. class Solution {
  13. public:
  14.     TreeNode* searchBST(TreeNode* root, int val) {
  15.         while(root!=nullptr)
  16.         {
  17.             if(root->val<val) root=root->right;
  18.             else if(root->val>val) root=root->left;
  19.             else return root;
  20.         }
  21.         return nullptr;
  22.     }
  23. };

递归试试:

递归还是写不出来,早上看过答案也写不出来,逻辑理不清,什么时候该创建变量去接住递归的结果?

  1. /**
  2.  * Definition for a binary tree node.
  3.  * struct TreeNode {
  4.  *     int val;
  5.  *     TreeNode *left;
  6.  *     TreeNode *right;
  7.  *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8.  *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9.  *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10.  * };
  11.  */
  12. class Solution {
  13. public:
  14.     TreeNode* searchBST(TreeNode* root, int val) {
  15.         if(root==nullptr||root->val==valreturn root;
  16.         TreeNode* result=nullptr;
  17.         if(root->val<val) {
  18.             result=searchBST(root->right,val);
  19.         }
  20.         if(root->val>val){
  21.             result=searchBST(root->left,val);
  22.         }
  23.         return result;
  24.     }
  25. };

递归没接住(没找到),就返回的是初始化的result=nullptr;

98验证二叉搜索树

有很多陷阱在里面。迭代法就很容易出错。

这里要知道并利用这个性质:二叉搜索树的中序遍历序列是严格单调增的数组。

  1. /**
  2.  * Definition for a binary tree node.
  3.  * struct TreeNode {
  4.  *     int val;
  5.  *     TreeNode *left;
  6.  *     TreeNode *right;
  7.  *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
  8.  *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
  9.  *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
  10.  * };
  11.  */
  12. class Solution {
  13. private:
  14.     vector<int> result;
  15.     void exc(TreeNode *root)
  16.     {
  17.         if(root==nullptrreturn;
  18.         exc(root->left);
  19.         result.push_back(root->val);
  20.         exc(root->right);
  21.     }
  22. public:
  23.     bool isValidBST(TreeNode* root) {
  24.         result.clear();
  25.         exc(root);
  26.         for(int i=1;i<result.size();i++)
  27.         {
  28.             if(result[i-1]>=result[i]) return false;
  29.         }
  30.         return true;
  31.     }
  32. };

http://www.ppmy.cn/server/40350.html

相关文章

gitee 简易使用 上传文件

Wiki - Gitee.com 官方教程 1.gitee 注册帐号 (直接选择初始化选项即可&#xff0c;无需下载git&#xff09; 2.下载git 安装 http://git-scm.com/downloads 3. 桌面 鼠标右键 或是开始菜单 open git bash here 输入&#xff08;复制 &#xff0c;粘贴&#xff09; 运行…

Scala网络爬虫实战:抓取QQ音乐的音频资源

引言 在当今数字化时代&#xff0c;互联网中蕴藏着海量的数据&#xff0c;而网络爬虫技术则是获取这些数据的重要工具之一。而Scala作为一种功能强大的多范式编程语言&#xff0c;结合了面向对象和函数式编程的特性&#xff0c;为网络爬虫开发提供了更多的可能性。在本文中&am…

【MySQL数据库开发设计规范】之表设计规范

欢迎点开这篇文章&#xff0c;自我介绍一下哈&#xff0c;本人姑苏老陈 &#xff0c;是一名JAVA开发老兵。 本文收录于 《MySQL数据库开发设计规范》专栏中&#xff0c;该专栏主要分享一些关于MySQL数据库开发设计相关的技术规范文章&#xff0c;定期更新&#xff0c;欢迎关注&…

用户登录后端:验签

前端请求拦截器 工具类 cryptomd5Util.js const crypto require(crypto) const publicKey xxxx export function encryptedHmacMd5Data(appid, data, timestamp) {const hmac crypto.createHmac(md5, publicKey)let params dataif (typeof data object) {for (const i in…

关于在ubuntu18.04中运行ORB_SLAM3时遇到的报错:段错误(核心已转储)的解决方法(踩坑记录)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、段错误&#xff08;核心已转储&#xff09;1. 已放弃(核心已转储)(1) 问题描述(2)原因分析 二、解决方法1. 解决方法一2. 解决方法二 总结 一、段错误&#xff…

算法提高之字串变换

算法提高之字串变换 核心思想&#xff1a;双向广搜 双向bfs 建立两个队列 一起bfs到中间态 #include <iostream>#include <cstring>#include <algorithm>#include <queue>#include <unordered_map>using namespace std;const int N 6;int n;…

Java SE基础知识(12)

知识梳理&#xff1a; package ZoomId;import java.time.ZoneId; import java.time.ZoneOffset; import java.time.ZonedDateTime; import java.util.Set;public class demo1 {public static void main(String[] args) {//获取所有的时区名称Set<String> availableZoneId…

SpringCloud:服务拆分和远程调用

程序员老茶 &#x1f648;作者简介&#xff1a;练习时长两年半的Java up主 &#x1f649;个人主页&#xff1a;程序员老茶 &#x1f64a; P   S : 点赞是免费的&#xff0c;却可以让写博客的作者开心好久好久&#x1f60e; &#x1f4da;系列专栏&#xff1a;Java全栈&#…