day02 有序数组的平方 长度最小子数组 螺旋矩阵

题目1:977  有序数组的平方

题目链接:977 有序数组的平方

题意 

返回非递减整数数组的每个数字的平方和  也按照递减排序

双指针★

代码

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

时间复杂度O(n)

空间复杂度O(n)

暴力解法

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

时间复杂度O(n+nlogn)

题目2:209  长度最小的子数组

题目链接:209 长度最小的子数组

题意

数组中含有n个正整数,返回数组中总和大于等于target的长度最小的连续子数组的长度,注意数组中一定要是正整数,因为只有正整数才会越加越大,如果没有则,返回0

滑动窗口★

思想:不断更新连续子数组的起始位置和终止位置,使用1个for循环就可以完成这些操作

for循环中的变量应该是终止位置,这样才能避免暴力解法两层for循环的情况

滑动窗口移动的条件:当前窗口的值大于等于s

遇到某个滑动窗口内的总和大于等于target,就移动这个滑动窗口的起始位置,看是否还有更短的长度的子数组满足大于等于target的条件;如果滑动窗口内的总和小于target,说明整个滑动窗口扩充的还不够长,于是需要移动终止位置

代码

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int i = 0;//滑动窗口起始位置int sum = 0;//总和int subL = 0;//子数组长度int result = INT32_MAX;for(int j = 0;j < nums.size();j++){sum += nums[j];  //子数组总和while(sum >= target){subL = j - i + 1;result = min(result,subL);sum -= nums[i];//将起始位置的数值从总和中减去i++; //注意同时移动起始位置}}return result==INT32_MAX ? 0 : result;}
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

暴力解法

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int result = INT32_MAX;int subL = 0;for(int i = 0;i < nums.size();i++){int sum = 0;for(int j = i;j < nums.size();j++){sum += nums[j];if(sum >= target){subL = j - i + 1;result = min(result,subL);break;//此处跳过for循环是因为数组中都是正整数,越往后加数值肯定越大,越满足sum>target}}}return result==INT32_MAX ? 0 : result;}
};
  • 时间复杂度:O(n^2)
  • 空间复杂度:O(1)

使用暴力解法会超时,如下图

题目3:59 螺旋矩阵Ⅱ

题目链接:59.螺旋矩阵Ⅱ

题意

正整数1~n^2的所有元素,按照顺时针排列成n*n的正方形矩阵,并按照矩阵的形式一行一行的输出

循环不变量

本题还是要坚持循环不变量原则,每一圈的处理规则要统一,均是左闭右开,由外向内一圈一圈画,每一圈都可以使用一套代码,每一圈的每一条边的情况列出来,遍历圈数

使用左闭右开的原则,即拐角处的元素放到下一条边处理    i代表行,j代表列

转的圈数是 n/2  的原因是:将整个正方形对半分,看一半有多少条边,就可以转多少圈

代码

class Solution {
public:vector<vector<int>> generateMatrix(int n) {vector<vector<int>> nums(n,vector<int>(n,0));int startx = 0;  //i的起始位置int starty = 0;  //j的终止位置int offset = 1;  //第一圈的偏移量int count = 1;   //每个位置的数,计数,不断累加int loop = n / 2;  //圈数int mid = n / 2;  //中间的位置int i,j;while(loop--){//上行   i代表行,j代表列   行不变,列++for(j = starty;j < n - offset;j++){nums[startx][j] = count++;//跳出循环时,i=startx,j=n-offset}//右列    行++,列不变for(i = startx;i < n - offset;i++){nums[i][j] = count++; //跳出循环时,i=n-offset,j=n-offset}//下行    行不变,列--for(;j > starty;j--){nums[i][j] = count++;//跳出循环时,i=n-offset,j=0}//左列    行--,列不变for(;i>startx;i--){nums[i][j] = count++;//跳出循环时,i=0,j=0}//进入下一圈做准备startx++;starty++;offset++;}if(n % 2 == 1) {nums[mid][mid] = count;  //这里不是i,j因为是i和j的话,指向的是最后一圈的第一个位置,不符}return nums;}
};
  • 时间复杂度 O(n^2): 模拟遍历二维矩阵的时间
  • 空间复杂度 O(1)

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

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

相关文章

VMware 虚拟机 ubuntu 20.04 硬盘扩容方法

前言 最近由于需要编译 【RK3568】的 Linux SDK&#xff0c;发现 虚拟机默认的 200G 空间不足了&#xff0c;因此想增加这个 200G 空间的限制&#xff0c;通过网络上查找了一些方法&#xff0c;加上自己亲自验证&#xff0c;确认 硬盘扩容 正常&#xff0c;方法也比较的容易&a…

Vue:Vue与VueComponent的关系图

1.一个重要的内置关系&#xff1a;VueComponent.prototype.proto Vue.prototype 2.为什么要有这个关系&#xff1a;让组件实例对象&#xff08;vc&#xff09;可以访问到 Vue原型上的属性、方法。 案例证明&#xff1a; <!DOCTYPE html> <html lang"en"&…

Java日期和时间(二)

新增的日期和时间 为什么要学习新增的日期和时间 1、代替Calendar LocalDate&#xff1a;年、月、日 LocalTime&#xff1a;时、分、秒 LocalDateTime&#xff1a;年、月、日、时、分、秒 ZoneId&#xff1a;时区 ZoneldDatetime&#xff1a;带时区的时间 2、代替Date Instan…

解决npm,pnpm,yarn等安装electron超时等问题

我在安装electron的时候&#xff0c;出现了超时等等各种问题&#xff1a; &#xff08;RequestError: connect ETIMEDOUT 20.205.243.166:443&#xff09; npm yarn&#xff1a;Request Error: connect ETIMEDOUT 20.205.243.166:443 RequestError: socket hang up npm ER…

【排序】堆排序(C语言实现)

文章目录 前言1. 堆排序1.1 堆排序的思想1.2 堆排序的实现 2. 为什么向下调整而不是向上调整 前言 本章主要会讲堆排序的实现过程以及向上调整和向下调整的时间复杂度&#xff0c;在学习本章前&#xff0c;需要对堆、以及向上调整和向下调整有一个了解&#xff0c;如果不了解的…

vite+Vue3学习笔记(3)——界面设计

1 Element-plus 这是一个基于Vue3的组件库&#xff0c;能够快速构建界面样式。 官网链接&#xff1a; https://element-plus.gitee.io/zh-CN/guide/design.html 1.1 基础组件 1.1.1 安装 项目中的终端输入&#xff1a; npm install --save element-plus 1.1.2 引用 1.1.2.1…

图论及其应用(匈牙利算法)---期末胡乱复习版

目录 题目知识点解题步骤小结题目 T1:从下图中给定的 M = {x1y4,x2y2,x3y1,x4y5},用 Hungariam算法【匈牙利算法】 求出图中的完美匹配,并写出步骤。 知识点 关于匈牙利算法: 需要注意的是,匈牙利算法仅适用于二分图,并且能够找到完美匹配。什么是交替路?从一个未匹…

BDD - Python Behave Retry 机制

BDD - Python Behave Retry 机制 引言Behave RetryBehave Retry 应用feature 文件创建 step 文件Retry运行 Behave 并生成 rerun 文件重新运行失败的场景 引言 在日常运行测试用例&#xff0c;有时因为环境不稳定造成一些测试用例跑失败了&#xff0c;如果能将这些失败的测试用…

计算字符串的长度几种方法 | 递归 | 指针减指针 | 计数器 | C语言 | 详解 | 期末考试必看!!!

一&#xff0c;使用 递归 计算 字符串 的 长度 1&#xff0c;题目描述 2&#xff0c;分析题目 Ⅰ&#xff0c;题目中要求除了函数的形参&#xff0c;函数中不能够使用多余的变量&#xff08;这是比较苛刻的要求&#xff09;。 Ⅱ&#xff0c;根据此&#xff0c;很自然的…

k3s-安装、卸载、证书过期x509

k3s-安装、卸载、证书过期 K3S 是轻量级的 Kubernetes。易于安装&#xff0c;仅需要 Kubernetes 内存的一半&#xff0c;所有组件都在一个小于 100 MB 的二进制文件中。 环境准备 # 配置yum源 yum install -y yum-utils yum-config-manager --add-repo http://mirrors.aliyu…

回归预测 | MATLAB实OOA-LSTM基于鱼鹰优化算法优化长短期记忆网络的多输入单输出数据回归预测模型 (多指标,多图)

回归预测 | MATLAB实OOA-LSTM基于鱼鹰优化算法优化长短期记忆网络的多输入单输出数据回归预测模型 &#xff08;多指标&#xff0c;多图&#xff09; 目录 回归预测 | MATLAB实OOA-LSTM基于鱼鹰优化算法优化长短期记忆网络的多输入单输出数据回归预测模型 &#xff08;多指标&a…

20231228在Firefly的AIO-3399J开发板的Android11的挖掘机的DTS配置单前置摄像头ov13850

20231228在Firefly的AIO-3399J开发板的Android11的挖掘机的DTS配置单前置摄像头ov13850 2023/12/28 10:42 【碰到一个很神奇的问题】&#xff1a; 昨天晚上前置摄像头怎么也点不亮&#xff01;改了巨多的地方&#xff01;晚上睡觉之前把开发板彻底断电了&#xff01;今天开电脑…

STM32的在线升级(IAP)实现方法:BOOT+APP原理详解

0 工具准备 Keil uVision5 Cortex M3权威指南&#xff08;中文&#xff09; STM32参考手册 1 在线升级&#xff08;IAP&#xff09;设计思路 为了实现STM32的在线升级&#xff08;IAP&#xff09;功能&#xff0c;通常会将STM32的FLASH划分为BOOT和APP两个部分&#xff0c;BOO…

虚幻UE 光源-色温和光度学

文章目录 一、色温二、光度学1、lux勒克斯2、cd坎德拉3、nit尼特4、总结 三、EV曝光值 一、色温 色温可以简单的认为就是颜色的温度。 但他是有范围的&#xff0c;也是有要求的&#xff0c;并不是所有的颜色都可以有色温。 以上就是色温范围图。 而这些颜色的温度是怎么定义…

【算法每日一练]-数论 (保姆级教程 篇2 )#行列式 #甜甜花研究 #约数个数 #模数 #数树 #盒子与球

目录 今日知识点&#xff1a; 辗转相减法化下三角求行列式 组合数动态规划打表 约数个数等于质因数的次方1的乘积 求一个模数 将n个不同的球放入r个不同的盒子&#xff1a;f[i][j]f[i-1][j-1]f[i-1][j]*j 行列式 甜甜花的研究 约数个数 模数 数树 盒子与球 行列…

github短视频去除水印项目Douyin_TikTok_Download_API介绍

当下正值短视频盛行的时代。在我们浏览短视频的同时&#xff0c;经常能发现一些精美的图片、引人入胜的文案以及吸引眼球的视频&#xff0c;想要将它们保存到本地。然而&#xff0c;保存下来的图片或视频通常伴随着不太愉悦的水印&#xff0c;这显著降低了使用体验。因此&#…

开源数据可视化分析工具DataEase本地部署并实现远程访问

目录 前言 1. 安装DataEase 2. 本地访问测试 3. 安装 cpolar内网穿透软件 4. 配置DataEase公网访问地址 5. 公网远程访问Data Ease 6. 固定Data Ease公网地址 结语 作者简介&#xff1a; 懒大王敲代码&#xff0c;计算机专业应届生 今天给大家聊聊开源数据可视化分析工…

element的form表单校验(身份证号、手机号、整数、汉字、for循环列表)

<template><div class"FormPage"><el-form ref"form" :model"form" :rules"rules" label-width"100px"><el-form-item label"姓名:" prop"name"><el-input v-model"fo…

25道RabbitMQ面试题含答案(很全)

1. 什么是RabbitMQ RabbitMQ是一个开源的消息队列系统&#xff0c;它使用AMQP&#xff08;高级消息队列协议&#xff09;标准。RabbitMQ的主要目标是提供可靠的消息传递&#xff0c;确保消息的可靠性和顺序性&#xff0c;同时提供灵活的路由和消息确认机制。 RabbitMQ基于AMQ…

Unity坦克大战开发全流程——游戏场景——游戏界面——设置界面复用

游戏场景——游戏界面——设置界面复用 先将开始场景当中的设置面板复制过来 由于设置面板挂载的脚本都是相同的&#xff0c;在BeginScene中关闭设置面板时不会报空&#xff0c;而在GameScene中关闭设置面板时却会报空&#xff0c;这是因为监听事件中的单例模式调用的实例是Beg…