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

相关文章

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引