代码随想录算法训练营Day2|977有序数组的平方 209.长度最小的子数组 59螺旋矩阵Ⅱ(C++)
LeetCode刷题,代码随想录算法训练营Day2
977.有序数组的平方
题目链接 : 977.有序数组的平方
题目思路:关键在于双指针思想的应用
输入:nums = [-4,-1,0,3,10]
输出:[0,1,9,16,100]
解释:平方后,数组变为 [16,1,0,9,100]
排序后,数组变为 [0,1,9,16,100]
暴力破解(sort方法、冒泡)
应该为一个for循环进行全部平方,直接调用sort进行排序即可,时间复杂度n+n*log2n
1 class Solution {
2 public:
3 vector<int> sortedSquares(vector<int>& nums) {
4 int i;
5 for(i=0;i<nums.size();i++){
6 nums[i]*=nums[i];
7 }
8 sort(nums.begin(),nums.end());
9 return nums;
10 }
11 };
如果使用冒泡排序时间复杂度会为n²
1 for(i=0;i<nums.size()-1;i++){
2 for(j=0;j<nums.size()-1-i;j++){
3 if(nums[j]>nums[j+1]){
4 swap(nums[j],nums[j+1]);
5 }
6 }
7 }
双指针法
和昨天的题目一样,通过双指针在一个for循环里做出两个for循环的事情。本题通过一前一后的双指针相向进行

如果A[i] * A[i] < A[j] * A[j] 那么result[k--] = A[j] * A[j]; 。
如果A[i] * A[i] >= A[j] * A[j] 那么result[k--] = A[i] * A[i]; 。
1 class Solution {
2 public:
3 vector<int> sortedSquares(vector<int>& A) {
4 int k = A.size() - 1; //索引的下标
5 vector<int> result(A.size(), 0);//定义新数组
6 for (int i = 0, j = A.size() - 1; i <= j;) { //循环终止, 注意这里要i <= j,因为最后要处理两个元素
7 if (A[i] * A[i] < A[j] * A[j]) {
8 result[k--] = A[j] * A[j];
9 j--;
10 }
11 else {
12 result[k--] = A[i] * A[i];
13 i++;
14 }
15 }
16 return result;
17 }
18 };
注意:不能再i=j的时候退出,否则中间两个无法比较。
由于i++和j--是有条件的,因此for循环的最后需要空着,自增自减在条件中进行完成。
209.长度最小的子数组
题目链接:209.长度最小的子数组
解题思路:
暴力解法
class Solution {
public:
int minSubArrayLen(int s, vector<int>& nums) {
int result = INT32_MAX; // 最终的结果
int 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 >= s) { // 一旦发现子序列和超过了s,更新result
subLength = j - i + 1; // 取子序列的长度
result = result < subLength ? result : subLength;
break; // 因为我们是找符合条件最短的子序列,所以一旦符合条件就break
}
}
}
// 如果result没有被赋值的话,就返回0,说明没有符合条件的子序列
return result == INT32_MAX ? 0 : result;
}
};
时间复杂度O(n²)
滑动窗口解法
滑动窗口即不断通过调节子序列的起始位置和最终位置,得出想要的结果
下标j应该为滑动窗口的终止位置。如果j是位于起始位置,则仍然是暴力解法。

当集合里的所有元素和大于s时再移动起始位置即可

可以发现滑动窗口的精妙之处在于根据当前子序列和大小的情况,不断调节子序列的起始位置。从而将O(n^2)暴力解法降为O(n)。
代码实现:
1 class Solution {
2 public:
3 int minSubArrayLen(int s, vector<int>& nums) {
4 int result = INT32_MAX;
5 int sum = 0; // 滑动窗口数值之和
6 int i = 0; // 滑动窗口起始位置
7 int subLength = 0; // 滑动窗口的长度
8 for (int j = 0; j < nums.size(); j++) {
9 sum += nums[j];
10 // 注意这里使用while,每次更新 i(起始位置),并不断比较子序列是否符合条件
11 while (sum >= s) {
12 subLength = (j - i + 1); // 取子序列的长度
13 result = result < subLength ? result : subLength;
14 sum -= nums[i++]; // 这里体现出滑动窗口的精髓之处,不断变更i(子序列的起始位置)
15 }
16 }
17 // 如果result没有被赋值的话,就返回0,说明没有符合条件的子序列
18 return result == INT32_MAX ? 0 : result;
19 }
20 };
59螺旋矩阵Ⅱ
题目链接:59螺旋矩阵Ⅱ
模拟解法
螺旋矩阵没有暴力破解,只能通过四个for循环重复实现对不同数字的输入。螺旋矩阵的重要点在于判断最后一个列的数字个数和奇数大小矩阵时的中间位置的数字。
整个矩阵的实现是由两组循环实现的,最外层是while循环,用来控制一周的整体循环,每一行通过一个for循环实现一行内的输入输出。
处理规则:循环不变量
按左闭右开的规则对各边进行遍历,都只处理第一个节点,最后一个节点不处理。
定义的i对应startx,j对应starty,二维数组中i控制行的数量,j控制列的数量,因此第一个for中就是只对j进行修改。外层修改完成后startx和starty都进行自增,内一层初始的节点位置沿对角线进行逐层深入。
每层长度通过offset进行控制,最外层就是1,每往内一层即+1
螺旋矩阵的数字输入通过count进行计数,在每个for循环内都要自增一次
1 class Solution {
2 public:
3 vector<vector<int>> generateMatrix(int n) {
4 vector<vector<int>> res(n, vector<int>(n, 0));//使用vector定义二维数组
5 int startx=0,starty=0;//定义循环一个圈的起始位置
6 short loop=n/2;//n==3时一次循环,n==4时2次循环完成
7 short mid=n/2;//中间的部分单独填充,位于中心位置
8 short count=1;//定义矩阵中每一个空格赋值,从1开始
9 short offset=1;//需要控制每一个边遍历的长度,每循环一次右边界收缩一位
10 short i,j;
11 while(loop--){
12 i=startx;
13 j=starty;
14 //四个for模拟转了一圈
15 //模拟填充上行从左到右(左闭右开)//x不变,j变化
16 for(j=starty;j<n-offset;j++){
17 res[startx][j]=count++;
18 }
19 //模拟填充右列从上到下
20 for(i=startx;i<n-offset;i++){
21 res[i][j]=count++;
22 }
23 //模拟填充下行从右到左
24 for(;j>starty;j--){
25 res[i][j]=count++;
26 }
27 for(;i>startx;i--){
28 res[i][j]=count++;
29 }
30 startx++;
31 starty++;//xy沿对角线向内移动
32 offset+=1;//offset控制每一圈里一条边遍历的长度
33 }
34 //n是奇数的话,需单独为中间的数赋值
35 if(n%2){
36 res[mid][mid]=count;
37 }
38 return res;
39 }
40 };
总结
除最后一个题目外,其他的数组题目都是对双指针思想的应用,双指针是通过指针的移动实现对一次for循环的取代,从而节约和降低时间复杂度。
由于之前没有学习过C++,现在用C++写代码有很多知识点还是比较难以理解的,现在虽然很吃力,但只要坚持就一定可以克服,加油!
代码随想录算法训练营Day2|977有序数组的平方 209.长度最小的子数组 59螺旋矩阵Ⅱ(C++)的更多相关文章
- 代码随想录算法训练营第二天| 977.有序数组的平方 ,209.长度最小的子数组 ,59.螺旋矩阵II
977.有序数组的平方 :https://leetcode.cn/problems/squares-of-a-sorted-array/ 心得:周末再写... public class Solutio ...
- 领扣-209 长度最小的子数组 Minimum Size Subarray Sum MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- 代码随想录训练营day 2 |977有序数组的平方 209.长度最小的子数组 (C++)
977.有序数组的平方 题目链接:977.有序数组的平方 题目描述:给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序. 例子如下: 输入 ...
- lc.209 长度最小的子数组
题目 给定一个含有 n 个正整数的数组和一个正整数 target . 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, n ...
- 【LeetCode】209. 长度最小的子数组
209. 长度最小的子数组 知识点:数组:前缀和:二分法:双指针:滑动窗口 题目描述 给定一个含有 n 个正整数的数组和一个正整数 target . 找出该数组中满足其和 ≥ target 的长度最小 ...
- Java实现 LeetCode 209 长度最小的子数组
209. 长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 0. 示例: 输入: s = ...
- 代码随想录第二天| 977.有序数组的平方 ,209.长度最小的子数组 ,59.螺旋矩阵II
2022/09/22 第二天 第一题 这题我就直接平方后排序了,很无脑但很快乐啊(官方题解是双指针 第二题 滑动窗口的问题,本来我也是直接暴力求解发现在leetCode上超时,看了官方题解,也是第一次 ...
- Leetcode 209.长度最小的子数组 By Python
给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 0. 示例: 输入: s = 7, nums = [2, ...
- LeetCode 209. 长度最小的子数组(Minimum Size Subarray Sum)
题目描述 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 0. 示例: 输入: s = 7, nums ...
- LeetCode:长度最小的子数组【209】
LeetCode:长度最小的子数组[209] 题目描述 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 ...
随机推荐
- 3.错误代码C4996
3.错误代码C4996 错误 C4996 'strcpy': This function or variable may be unsafe. Consider using strcpy_s inst ...
- 改进 hibernate-validator,新一代校验框架 validator 使用介绍 v0.4
项目介绍 java 开发中,参数校验是非常常见的需求.但是 hibernate-validator 在使用过程中,依然会存在一些问题. validator 在 hibernate-validator ...
- 【转载】谈谈GIS三维渲染引擎
> 原文地址:https://zhuanlan.zhihu.com/p/419667971 三维引擎 minemap: 是我们公司的产品,主要以earth的形态展示,支持矢量切片+倾斜数据(这一 ...
- 分布式事务组件Seata
介绍 一阶段:事务协调者通知每一个服务处理本地事务,每个服务开始处理但是不会提交事务,处理完毕后告知协调者. 二阶段:协调者收到所有服务的消息后通知他们提交事务. 重要角色 事务管理器(TM),决 ...
- 【Visual Leak Detector】QT 中 VLD 输出解析(四)
说明 使用 VLD 内存泄漏检测工具辅助开发时整理的学习笔记. 目录 说明 1. 使用方式 2. 测试代码 3. 使用 32 bit 编译器时的输出 4. 使用 64 bit 编译器时的输出 5. 输 ...
- TS 导入导出那些事
前言 最近用 TypeScript 写 npm 包,各种模块.命名空间.全局定义等等扰得我睡不着觉. 我便苦心研究,总结了几个比较冷门的,国内貌似基本上找不到资料的导入导出用法,顺便在其中又插入一些不 ...
- day31:socketserver&hashlib&hmac&TCP登录
目录 1.socketserver:实现TCP协议下Server端的并发 2.hashlib模块 3.hashlib应用:文件校验 4.hmac应用:服务器的合法性校验 5.TCP登录程序 1.soc ...
- 服务器数据监控监控-Zabbix
Zabbix下载 Zabbix Sources https://www.zabbix.com/download Zabbix安装介绍 Server端 1.安装开发软件包 yum -y groupins ...
- 新一代自动化测试神器Playwright
转载请注明出处️ 作者:测试蔡坨坨 原文链接:caituotuo.top/4bedb73c.html 你好,我是测试蔡坨坨. 说到WebUI自动化测试,首当其冲的当属Selenium,在很长的一段时间 ...
- .Net 6.0 部署Linux+Nginx +PM2教程
今天带大家将本地.Net6.0项目部署到Linux系统中,其中有用到Nginx反向代理和PM2进程管理工具,希望本偏文章能对你有所帮助,成为你成功路上的垫脚石! 背景: 在.Net 5.0横空出世之后 ...