代码随想录刷题题Day2

刷题的第二天,希望自己能够不断坚持下去,迎来蜕变。😀😀😀
刷题语言:C++ / Python
Day2 任务
977.有序数组的平方
209.长度最小的子数组
59.螺旋矩阵 II

1 有序数组的平方(重点:双指针思想

在这里插入图片描述

1.1 暴力

思路:将数组里面所有元素平方,再排序。
时间复杂度: O ( n + n l o g n ) O(n + nlogn) O(n+nlogn)
C++:

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;}
};

Python:

class Solution(object):def sortedSquares(self, nums):for i in range(len(nums)):nums[i] *= nums[i]nums.sort()return nums
1.2 双指针(非常重要的思想)

在这里插入图片描述
非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序
数组里面的元素平方之后,元素趋势如下图所示
在这里插入图片描述
数组平方的最大值就在数组的两端,考虑双指针,i指向起始位置,j指向终止位置
伪代码:

vector<int> result;
k = nums.size - 1;
for(i = 0, j = nums.size-1;i<=j;) # i <= j,因为最后要处理两个元素if(nums[i]*nums[i]>nums[j]*nums[j])result[k--] = nums[i]*nums[i]i++elseresult[k--] = nums[j]*nums[j]j--
return result

时间复杂度: O ( n ) O(n) O(n)
C++:

class Solution {
public:vector<int> sortedSquares(vector<int>& nums) {int k = nums.size() - 1;vector<int> result(nums.size(), 0);for (int i = 0, j = nums.size() - 1; i <= j; ){if (nums[i] * nums[i] > nums[j] * nums[j]){result[k--] = nums[i] * nums[i];i++;}else{result[k--] = nums[j] * nums[j];j--;}}return result;}
};

Python:

class Solution(object):def sortedSquares(self, nums):i,j,k = 0, len(nums) - 1, len(nums) - 1res = [float('inf')] * len(nums)while i <= j:if nums[i] ** 2 > nums[j] ** 2:res[k] = nums[i] ** 2i += 1else:res[k] = nums[j] ** 2j -= 1k -= 1return res

2 长度最小的子数组 - (滑动窗口

在这里插入图片描述

2.1 暴力解法

两个for循环,不断寻找符合条件的子序列
更新起始位置,终止位置每次都是一直往后遍历
时间复杂度: O ( n 2 ) O(n^2) O(n2)
C++:

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int res = INT32_MAX;// 2147483647int sum = 0;// 子序列数值之和int subLength = 0;// 子序列的长度for (int i = 0; i < nums.size(); i++) // 起点i{sum = 0;for (int j = i; j < nums.size(); j++) // 终止位置j{sum += nums[j];if (sum >= target) // 子序列和超过了s,更新result{subLength = j - i + 1; // 子序列的长度res = res < subLength ? res : subLength;break;}}}return res == INT32_MAX ? 0 : res;}
};
2.2 滑动窗口解法

在这里插入图片描述

时间复杂度 O ( n ) O(n) O(n)
滑动窗口:不断的调节子序列的起始位置和终止位置,得出想要的结果
用一个for循环来做2个for循环所做的事情

索引下标j表示的是滑动窗口里面的终止位置
假设是起始位置,for循环一次一次往后移动,这个终止位置要把后面所有的元素都遍历一遍,这种就和暴力解法没有区别。
因此,这个for循环里面的j一定指向的是终止位置,而起始位置需要用动态移动(滑动窗口的精髓)的策略来移动起始位置。

解题关键:移动窗口的起始位置
终止位置随着for循环一个一个向后移动,集合里的元素之和sum>=target时,说明这个集合满足条件,收集这个集合的长度,起始位置就可以移动了。
就是当我们发现集合里面所有的元素和 >= target,我们再去移动起始位置,这样就实现了动态调整起始位置,来去收集不同长度区间里面的和

❗应该写if(sum >= target)还是 while(sum >= target)
输入:target = 100, nums = [1,1,1,1,1,100]
如果是if,那么会漏掉其他情况

C++:

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int res = INT32_MAX; // 2147483647int i = 0; // 起始位置int sum = 0; // 子序列的和int subLength = 0; // 子序列的长度for (int j = 0; j < nums.size(); j++) // 更新终止位置{sum += nums[j];while (sum >= target) // 动态移动起始位置{subLength = j - i + 1; // 子序列的长度res = res < subLength ? res : subLength; // 记录较小的长度sum -= nums[i++]; // 移动起始位置i+1}}return res == INT32_MAX ? 0 : res; // 如果等于INT32_MAX,说明没有找到满足条件的子序列}
};

时间复杂度是O(n)
for循环里放一个while就认为是 O ( n 2 ) O(n^2) O(n2)是错误的,主要是看每一个元素被操作的次数,每个元素在滑动窗口后进来操作一次,出去操作一次,每个元素都是被操作两次,所以时间复杂度是 O ( 2 n ) O(2n) O(2n),也就是 O ( n ) O(n) O(n)

Python:

class Solution(object):def minSubArrayLen(self, target, nums):""":type target: int:type nums: List[int]:rtype: int"""l = len(nums)res = float('inf')i = 0 # 起始位置subLength = 0 # 子序列的长度cur_sum = 0 # 子序列和j = 0 # 终止位置while j < l:cur_sum += nums[j]while cur_sum >= target:subLength = j - i + 1res = min(res, subLength)cur_sum -= nums[i]i += 1j += 1return res if res != float('inf') else 0

3 螺旋矩阵

在这里插入图片描述
本题的求解依然要坚持循环不变量原则
坚持每条边左闭右开的原则
在这里插入图片描述
伪代码:

startx = 0;
starty = 0;
offset = 1; # 控制终止位置
count = 1;
while(n/2)
{i = startx;j = starty;for (j = starty; j < n - offset; j++){nums[startx][j] = count++;}for (i = startx; i < n - offset;i++){nums[i][j] = count++;}for (; j > starty; j--){nums[i][j] = count++;}for (; i > startx; i--){nums[i][j] = count++;}startx++;starty++;offset++;
}
if (n % 2)
{nums[n/2][n/2] = count;
}
return nums

C++:

class Solution {
public:vector<vector<int>> generateMatrix(int n) {vector<vector<int>> nums(n, vector<int> (n ,0); // 定义二维数组int i,j;int startx = 0; // // 定义每循环一个圈的起始位置int starty = 0;int offset = 1;   // 需要控制每一条边遍历的长度,每次循环右边界收缩一位int mid = n / 2;  // 矩阵的中间位置int loop = n / 2; // 循环次数int count = 1;while (loop--){i = startx;j = starty;// 填充上行从左到右(左闭右开)for (j = starty; j < n - offset; j++){nums[startx][j] = count++;}// 填充右列从上到下(左闭右开)for (i = startx; i < n - offset; i++){nums[i][j] = count++;}// 填充下行从右到左(左闭右开)for ( ; j > starty; j--){nums[i][j] = count++;}// 填充左列从下到上(左闭右开)for ( ; i > startx; i--){nums[i][j] = count++;}offset++;// 第二圈开始的时候,起始位置要各自加1startx++;starty++;}if (n % 2)// 如果n为奇数的话,需要单独给矩阵最中间的位置赋值{nums[mid][mid] = count;}return nums;}
};

Python:

class Solution(object):def generateMatrix(self, n):""":type n: int:rtype: List[List[int]]"""nums = [[0] * n for _ in range(n)]mid = n // 2  # 矩阵的中心点loop = n // 2 # 迭代次数# 起始点startx = 0starty = 0count = 1offset = 1    # 偏移量while loop:i = startxj = startywhile j < n - offset:nums[startx][j] = countcount += 1j += 1while i < n - offset:nums[i][j] = countcount += 1i += 1while j > starty:nums[i][j] = countcount += 1j -= 1while i > startx:nums[i][j] = countcount += 1i -= 1startx += 1starty += 1offset += 1loop -= 1if n % 2 != 0:nums[mid][mid] = countreturn nums

今天真是搞了不少时间,鼓励坚持两天的自己😀😀😀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/187898.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

将项目放到gitee上

参考 将IDEA中的项目上传到Gitee仓库中_哔哩哔哩_bilibili 如果cmd运行ssh不行的话&#xff0c;要换成git bash 如果初始化后的命令用不了&#xff0c;直接用idea项放右键&#xff0c;用git工具操作

XXL-Job详解(二):安装部署

目录 前言环境下载项目调度中心部署执行器部署 前言 看该文章之前&#xff0c;最好看一下之前的文章&#xff0c;比较方便我们理解 XXL-Job详解&#xff08;一&#xff09;&#xff1a;组件架构 环境 Maven3 Jdk1.8 Mysql5.7 下载项目 源码仓库地址链接: https://github.…

前端对浏览器的理解

浏览器的主要构成 用户界面 &#xff0d; 包括地址栏、后退/前进按钮、书签目录等&#xff0c;也就是你所看到的除了用来显示你所请求页面的主窗口之外的其他部分。 浏览器引擎 &#xff0d; 用来查询及操作渲染引擎的接口。 渲染引擎 &#xff0d; 用来显示请求的内容&#…

某60区块链安全之薅羊毛攻击实战一学习记录

区块链安全 文章目录 区块链安全薅羊毛攻击实战一实验目的实验环境实验工具实验原理实验内容薅羊毛攻击实战一 实验步骤EXP利用 薅羊毛攻击实战一 实验目的 学会使用python3的web3模块 学会分析以太坊智能合约薅羊毛攻击漏洞 找到合约漏洞进行分析并形成利用 实验环境 Ubun…

JVM类加载与运行时数据区

目录 一、类加载器 jvm类的加载过程 第一阶段&#xff1a;加载 第二阶段&#xff1a;链接阶段 第三阶段&#xff1a;初始化阶段&#xff1a; 双亲委派机制 沙箱安全机制 运行时数据区 栈-Xss1m 堆 TLAB 逃逸分析 方法区 常量池中有什么 StringTable为什么要调整位…

VS Code C++可视化调试配置Natvis,查看Qt、STL变量内容

VS Code C可视化调试配置Natvis 使用GlobalVisualizersDirectory Windows下 C:\Users\YourName\.vscode\extensions\ms-vscode.cpptools-1.18.5-win32-x64\debugAdapters\vsdbg\bin\Visualizers\Linux下 ~\.vscode\extensions\ms-vscode.cpptools-1.18.5-win32-x64\debugAd…

Spring Cloud 原理(第一节)

一、百度百科 Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发&#xff0c;如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等&#xff0c;都可以用Spring Boot的开发风格做到一键启动和部署。Spri…

实验五 C语言函数程序设计习题 (使用函数计算两点间的距离,请编写函数fun,使用函数输出字符矩阵,使用函数求最大公约数和最小公倍数)

1. 使用函数计算两点间的距离&#xff1a;给定平面任意两点坐标(x1,y1)和(x2,y2)&#xff0c;求这两点之间的距离(保留2位)小数。要求定义和调用dist(x1,y1,x2,y2)计算两点间的距离。坐标中两点坐标之间的距离公式如下&#xff1a; #include <stdio.h> #include <math…

1.ORB-SLAM3中如何保存多地图、关键帧、地图点到二进制文件中

1 保存多地图 1.1 为什么保存(视觉)地图 因为我们要去做导航&#xff0c;导航需要先验地图。因此需要保存地图供导航使用&#xff0c;下面来为大家讲解如何保存多地图。 1.2 保存多地图的主函数SaveAtlas 2051 mStrSaveAtlasToFile是配置文件中传递的参数&#xff1a; 这里我们…

ssh远程连接阿里云CentOS:修改为密码登录

文章目录 控制台添加密钥下载Xshell修改密码连接重启服务&#xff1a;重复Xshell使用密码登录 控制台添加密钥 会下载一个pem文件 下载Xshell 新建 通过public key登录 修改密码连接 passwd root然后输入你想要设置的密码两遍 cd /etc/ssh/ vi sshd_config将PasswordAuth…

[论文精读]利用大语言模型对扩散模型进行自我修正

本博客是一篇最新论文的精读&#xff0c;论文为UC伯克利大学相关研究者新近(2023.11.27)在arxiv上上传的《Self-correcting LLM-controlled Diffusion Models》 。 内容提要: 现有的基于扩散的文本到图像生成模型在生成与复杂提示精确对齐的图像时仍然存在困难,尤其是需要数值和…

生成对抗网络(DCGAN)手写数字生成

文章目录 一、前言二、前期工作1. 设置GPU&#xff08;如果使用的是CPU可以忽略这步&#xff09; 二、什么是生成对抗网络1. 简单介绍2. 应用领域 三、创建模型1. 生成器2. 判别器 四、定义损失函数和优化器1. 判别器损失2. 生成器损失 五、定义训练循环六、训练模型七、创建 G…

“前端八股文背诵版“,终于整理完了,堪称最强!

随着互联网的快速发展&#xff0c;前端开发领域成为了IT行业中的热门领域之一。很多求职者都希望能够进入这个领域&#xff0c;但是面对着如此激烈的竞争&#xff0c;很多人都感到无从下手。为了帮助大家更好地掌握前端开发的相关知识&#xff0c;小编整理了一份前端面试题合集…

单片机怎么实现真正的多线程?

单片机怎么实现真正的多线程? 不考虑多核情况时&#xff0c;CPU在一个时间点只能做一件事&#xff0c;因为切换的速度快所以看起来好像是同时执行多个线程而已。 实际上就是用定时器来做时基&#xff0c;以时间片的方式分别执行来实现的&#xff0c;只不过实现起来细节比较复…

网络安全应急响应-Server2228(环境+解析)

网络安全应急响应 任务环境说明: 服务器场景:Server2228(开放链接)用户名:root,密码:p@ssw0rd123

【代码】考虑差异性充电模式的电动汽车充放电优化调度matlab-yalmip-cplex/gurobi

程序名称&#xff1a;考虑差异性充电模式的电动汽车充放电优化调度 实现平台&#xff1a;matlab-yalmip-cplex/gurobi 代码简介&#xff1a;提出了一种微电网中电动汽车的协调充电调度方法&#xff0c;以将负荷需求从高峰期转移到低谷期。在所提出的方法中&#xff0c;基于充…

RHEL8.9 静默安装Oracle19C

RHEL8.9 静默安装Oracle19C 甘肃圆角网络科技开发有限公司 说明(GUI)&#xff1a;  1.实际业务场景中&#xff0c;Linux环境一般情况下是没有GUI的。没有GUI并不意味着没有安装图形界面。可能在部署Linux操作系统环境的时候安装了桌面环境&#xff0c;只是启动的时候设置了启动…

英国人工智能初创公司Stability AI面临卖身压力;深度学习中的检索增强生成简介

&#x1f989; AI新闻 &#x1f680; 英国人工智能初创公司Stability AI面临卖身压力 摘要&#xff1a;多位知情人士透露&#xff0c;英国人工智能初创公司Stability AI正寻求出售公司&#xff0c;因为投资者对其财务状况的压力越来越大。管理层最近几周一直将自己标榜为收购…

MapInfo Pro错误提示:This operation requires elevated privileges……

尝试删除MapInfo Pro时出现错误“此操作需要提升权限。将产品DVD/CD插入媒体播放器并双击setup.exe文件重新启动。此安装程序现在将中止。”。 原因&#xff1a; 这可能是由于权限问题。 解决方式&#xff1a; 1.如果MapInfo Pro setup.exe可用&#xff0c;请执行以下步骤&…

笔记64:Bahdanau 注意力

本地笔记地址&#xff1a;D:\work_file\&#xff08;4&#xff09;DeepLearning_Learning\03_个人笔记\3.循环神经网络\第10章&#xff1a;动手学深度学习~注意力机制 a a a a a a a a a a a