2024-04-04-代码随想录算法训练营第一天[LeetCode977有序数组平方、LeetCode209长度最小字数组、59螺旋矩阵II]

本文主要是介绍2024-04-04-代码随想录算法训练营第一天[LeetCode977有序数组平方、LeetCode209长度最小字数组、59螺旋矩阵II],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 第一题
    • 解法一[双指针法]
    • 解法二[暴力法]
    • 总结
  • 第二题
    • 解法一[暴力法]
    • 解法二[滑动窗口]
    • 总结
  • 第三题
    • 解法一[左闭右闭]
    • 解法二[左闭右开]
    • 总结:
  • 学到的基础知识
    • Int 极限值
    • 二维数组定义
    • 迭代器
    • array与vector

第一题

LeetCode977有序数组平方

解法一[双指针法]

class Solution {
public:vector<int> sortedSquares(vector<int>& nums) {// 双指针法int left = 0;int right = nums.size() - 1;int index = right;vector<int> new_nums(nums);while (left <= right){if (nums[left] * nums [left] > nums[right] * nums[right]){new_nums[index--] = nums[left] * nums [left];left++;}else {new_nums[index--] = nums[right] * nums[right];right--;}}return new_nums;}
};

解法二[暴力法]

class Solution {
public:vector<int> sortedSquares(vector<int>& nums) {//暴力法for (int i = 0; i < nums.size(); i++){nums[i] *= nums[i];}sort(nums.begin(), nums.end());return nums;}
};

总结

  • 状态:这道题也做过,所以还是比较顺利地做出来了.
  • 关键点:关键在于最大值只有可能出现在数组两端.
  • sort为快排,时间复杂度为O(n*logn)

第二题

LeetCode209长度最小字数组

解法一[暴力法]

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {//暴力解法 会超时int min_length = nums.size() + 1;for (int i = 0; i < nums.size(); i++){int sum = 0;for (int j = i; j < nums.size(); j++){sum += nums[j];while (sum >= target){min_length = j - i + 1 < min_length ? (j - i + 1) : min_length;break;}}}return min_length == nums.size() + 1 ? 0 : min_length;}
};

解法二[滑动窗口]

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {// 滑动窗口解法int left= 0;int sum = 0;int min_length = __INT32_MAX__;for (int right = 0; right < nums.size(); right++){sum += nums[right];while(sum >= target){min_length = (right - left + 1) < min_length ? (right - left + 1) : min_length;sum -= nums[left++];}}return min_length == __INT32_MAX__? 0 : min_length;}
};

总结

  • 状态: 只写出来暴力解法, 滑动窗口还是没写出来.
  • 关键点: 滑动窗口在于巧妙利用结束位置来更新起始位置, 由于是叠加, 直接减去起始位置的值则可以从新的起始点计算.
  • 算法思想: left指针表示子数组的起始位置, right指针表示子数组结束位置.当子数组的和值大于target, 则需要更新起始位置. 因为这时可以获得一个子数祖的长度, 然后while的意义就是在这个子数组里面找到比它更小的子数组长度. 跳出while后, 需要从上一个子数组的起始位置之后开始寻找.
  • 算法关键处举例理解: 当前面的数都比较小,然后跟一个比较大的数字后,首先计算子数组和会开始都小于target,而碰到较大的数后就超过target了,但此时如果去掉最前面的比较小的数也可以超过target,例如在[1, 1, 1, 1, 6, 2]中找到target=7就需要一直从第一个加到第五个数才会进入while,然后才继续在这个子数组里面找更小的子数组,一直循环到单独一个数字6小于7才会跳出while,此时以left = 0, 1, 2, 3开头的子数组都已经遍历完了,继续从left=4开始的子数组遍历.
  • 这题区间的定义为左闭右闭.
  • 32位最大int值为__INT32_MAX__.

第三题

LeetCode59螺旋矩阵II

解法一[左闭右闭]

class Solution {
public:vector<vector<int>> generateMatrix(int n) {// 左闭右闭vector<vector<int>> matrix(n, vector<int>(n, 0));int loop = 1; //loop表示圈数int x = 0; // x起始坐标int y = 0; // y起始坐标int k = 1;int length = n - 1; // 圈边的长度while (loop <= n / 2){// 从左到右for (int i = x, j = y; j <= y + length - 1; j++){matrix[i][j] = k++;}//从上到下for (int i = x, j = y + length; i <= x + length - 1; i++){matrix[i][j] = k++;}// 从右到左for (int i = x + length, j = y + length; j >= y + 1; j--){matrix[i][j] = k++;}// 从下到上for (int i = x + length , j = y; i >= x + 1; i--){matrix[i][j] = k++;}x++;y++;length -= 2;loop++;}if ((n % 2) != 0){matrix[n / 2][n / 2] = k;}return matrix;}
};

解法二[左闭右开]

class Solution {
public:vector<vector<int>> generateMatrix(int n) {// 左闭右开vector<vector<int>> matrix(n, vector<int>(n, 0));int x = 0;int y = 0;int loop = n / 2;int count = 1;int offset = 1;int i, j;while (loop--){i = x;j = y;for (j = y; j < n - offset; j++){matrix[i][j] = count++;}for (i = x; i < n - offset; i++){matrix[i][j] = count++;}for (; j > y; j--){matrix[i][j] = count++;}for (; i > x; i--){matrix[i][j] = count++;} x++;y++;offset++;}if ( n % 2 != 0){matrix[n / 2][n / 2] = count;}return matrix;}
};

总结:

  • 状态:较为艰难的写出来了左闭右闭.

  • 关键点:主要在于需要想到转圈的方法,不断更新圈的起始位置,然后从左到右,从上到下,从右到左,从下到上遍历,需要处理好边界问题.

  • 左闭右开和左闭右闭再次用到.

学到的基础知识

Int 极限值

int max_value = __INT32_MAX__;

二维数组定义

vector<vector<int>> matrix(n); // 先指定一维数组大小
vector<vector<int>> matrix(n, vector<int>(n, 0)); //定义一个n * n的二维矩阵

迭代器

sort(nums.begin(), nums.end());

nums.begin()指向第一个元素, nums.end()指向最后一个元素的后一个元素.

array与vector

可查看

这篇关于2024-04-04-代码随想录算法训练营第一天[LeetCode977有序数组平方、LeetCode209长度最小字数组、59螺旋矩阵II]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2