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

相关文章

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L