2024.06.21 刷题日记

2024-06-22 08:12
文章标签 21 刷题 日记 2024.06

本文主要是介绍2024.06.21 刷题日记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

101. 对称二叉树

判断是否对称,检查 root->left->val == root->right->val,接着进行递归检查对称位置:

class Solution {
public:// 传入对称位置的两个对称位置bool isMirror(TreeNode* left, TreeNode* right) {if (!left && !right)return true;if (!left || !right)return false;if (left->val != right->val)return false;return isMirror(left->left, right->right) &&isMirror(left->right, right->left);}bool isSymmetric(TreeNode* root) {if (!root)return true;return isMirror(root->left, root->right);}
};

543. 二叉树的直径

求二叉树的直径,就是在求当前节点左子树的深度和右子树的深度,两者一加,然后求最大值就可以了:

class Solution {
private:int maxDiameter = 0;int maxDepth(TreeNode* node) {if (!node)return 0;int leftMax = maxDepth(node->left);int rightMax = maxDepth(node->right);maxDiameter = max(leftMax + rightMax, maxDiameter);return max(leftMax, rightMax) + 1;}public:int diameterOfBinaryTree(TreeNode* root) {maxDepth(root); // 开始递归计算深度,并更新直径return maxDiameter;}
};

102. 二叉树的层序遍历

这个就是 bfs,直接利用队列:

class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {deque<TreeNode*> que; // 性能好if (!root)return {};vector<vector<int>> ans;vector<int> ansi;que.push_back(root);while (!que.empty()) {// 一次处理一层int levelSize = que.size();for (int i = 0; i < levelSize; i++) {TreeNode* temp = que.front();que.pop_front();ansi.push_back(temp->val);if (temp->left)que.push_back(temp->left);if (temp->right)que.push_back(temp->right);}ans.push_back(std::move(ansi));}return ans;}
};

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

这道题的思路是,直接找数组的中间节点为根节点,这把数组分为两部分,然后递归创建二叉树:

class Solution {
public:TreeNode* sortedArrayToBST(vector<int>& nums) {return createBST(nums, 0, nums.size() - 1);}TreeNode* createBST(const vector<int>& nums, int left, int right) {if (left > right) {return nullptr; }int mid = left + (right - left) / 2;TreeNode* node = new TreeNode(nums[mid]);node->left = createBST(nums, left, mid - 1);node->right = createBST(nums, mid + 1, right);return node;}
};

98. 验证二叉搜索树

依然是递归的思路:每次将当前节点的值作为验证左子树的最大值,作为验证右子树的最大值:

class Solution {
public:bool isValidBST(TreeNode* root) {return isValidBSTHelper(root, LONG_MIN, LONG_MAX);}private:bool isValidBSTHelper(TreeNode* node, long minVal, long maxVal) {if (!node)return true;if (node->val <= minVal || node->val >= maxVal)return false;return isValidBSTHelper(node->left, minVal, node->val) &&isValidBSTHelper(node->right, node->val, maxVal);}
};

230. 二叉搜索树中第K小的元素

这是搜索树,而搜索树的中序遍历顺序就是有序,因此可以中序遍历此树,然后将第 k 个值赋给变量 result ,然后返回:

class Solution {
public:int kthSmallest(TreeNode* root, int k) {int count = 0; int result = 0;inorder(root, k, count, result);return result;}private:void inorder(TreeNode* node, int k, int& count, int& result) {if (!node)return;// 遍历左子树inorder(node->left, k, count, result);// 访问当前节点++count;if (count == k) {result = node->val; return;  }// 遍历右子树inorder(node->right, k, count, result);}
};

总结

  1. 对称二叉树 (LeetCode 101):

    • 通过递归检查树的左右子树是否是镜像对称的。这涉及到对树的每个节点进行比较。
  2. 二叉树的直径 (LeetCode 543):

    • 计算每个节点的左右子树的最大深度,然后用它们的和更新最大直径。这也是通过递归实现的。
  3. 二叉树的层序遍历 (LeetCode 102):

    • 使用队列进行广度优先搜索(BFS),一层层地处理树中的每个节点。
  4. 将有序数组转换为二叉搜索树 (LeetCode 108):

    • 通过递归选择数组的中间元素作为树的节点,以此来保证树的平衡。
  5. 验证二叉搜索树 (LeetCode 98):

    • 利用递归和范围限制(最小值和最大值)来确保所有的节点符合二叉搜索树的性质。
  6. 二叉搜索树中第K小的元素 (LeetCode 230):

    • 通过中序遍历来访问节点,因为中序遍历二叉搜索树会按照元素的升序进行。

这篇关于2024.06.21 刷题日记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1083738

相关文章

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

【每日刷题】Day113

【每日刷题】Day113 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 91. 解码方法 - 力扣(LeetCode) 2. LCR 098. 不同路径 - 力扣(LeetCode) 3. 63. 不同路径 II - 力扣(LeetCode) 1. 91. 解码方法 - 力扣(LeetCode) //思路:动态规划。 cl

【JavaScript】LeetCode:21-25

文章目录 21 最大子数组和22 合并区间23 轮转数组24 除自身以外数组的乘积25 缺失的第一个正数 21 最大子数组和 贪心 / 动态规划贪心:连续和(count)< 0时,放弃当前起点的连续和,将下一个数作为新起点,这里提供使用贪心算法解决本题的代码。动态规划:dp[i]:以nums[i]为结尾的最长连续子序列(子数组)和。 dp[i] = max(dp[i - 1]

react笔记 8-21 约束性 表单

1、约束性组件和非约束性组件 非约束性组件<input type="text" name="" defaultValue={this.state.msg}></input>这里他的value是用户输入的值 并没有执行操作 只是获取到了msg的值 用户输入不会改变数据非约束性组件需要使用defaultValue获取数据 否则会报错约束性组件<input type="text

hot100刷题第1-9题,三个专题哈希,双指针,滑动窗口

求满足条件的子数组,一般是前缀和、滑动窗口,经常结合哈希表; 区间操作元素,一般是前缀和、差分数组 数组有序,更大概率会用到二分搜索 目前已经掌握一些基本套路,重零刷起leetcode hot 100, 套路题按套路来,非套路题适当参考gpt解法。 一、梦开始的地方, 两数之和 class Solution:#注意要返回的是数组下标def twoSum(self, nums: Lis

代码随想录刷题day25丨491.递增子序列 ,46.全排列 ,47.全排列 II

代码随想录刷题day25丨491.递增子序列 ,46.全排列 ,47.全排列 II 1.题目 1.1递增子序列 题目链接:491. 非递减子序列 - 力扣(LeetCode) 视频讲解:回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列_哔哩哔哩_bilibili 文档讲解:https://programmercarl.com/0491.%E9%80%92%E

代码随想录刷题day24丨93.复原IP地址 ,78.子集 , 90.子集II

代码随想录刷题day24丨93.复原IP地址 ,78.子集 , 90.子集II 1.题目 1.1复原IP地址 题目链接:93. 复原 IP 地址 - 力扣(LeetCode) 视频讲解:回溯算法如何分割字符串并判断是合法IP?| LeetCode:93.复原IP地址_哔哩哔哩_bilibili 文档讲解:https://programmercarl.com/0093.%E5%A4%8

研1日记5

x = torch.tensor(x),numpy 转tensor 三维矩阵相加 screen -S pid 进入之前创建好的screen transpose()只能一次操作两个维度;permute()可以一次操作多维数据,且必须传入所有维度数, transpose()中的dim没有数的大小区分;permute()中的dim有数的大小区分 PyTorch 两大转置函数 trans

【笔记】数据结构刷题09

快速排序 215. 数组中的第K个最大元素 class Solution {public:int findKthLargest(vector<int>& nums, int k) {return divide(nums,0,nums.size()-1,nums.size()-k);}int divide(vector<int>& nums,int left,int right,int k)

C语言:刷题日志(1)

一.阶乘计算升级版 本题要求实现一个打印非负整数阶乘的函数。 其中n是用户传入的参数,其值不超过1000。如果n是非负整数,则该函数必须在一行中打印出n!的值,否则打印“Invalid input”。 首先,知道阶乘是所有小于及等于该数的正整数的积,并且0的阶乘为1。那么我们先来个简单的阶乘计算吧。 #include<stdio.h>int Fact(int n){if (n <=