算法打卡day2|数组篇|Leetcode 977.有序数组的平方、 209.长度最小的子数组、59.螺旋矩阵II
算法题
Leetcode 977.有序数组的平方
题目链接: 977.有序数组的平方
大佬视频讲解:977.有序数组的平方
个人思路
第一时间就只想到暴力解法,双重循环一个循环比较一个循环赋值;但这样可能会超时,所以还能用双指针,因为这个数组是递增数组,也就是说平方后最大的值只能在两边,那么前后各一个指针,比较其值,再根据大小放进新的数组中就能解决,这也是空间换时间的方法;
解法
暴力解法
循环赋值然后排序;
class Solution {public int[] sortedSquares(int[] nums) {for(int i=0;i<nums.length;i++){//暴力循环求值nums[i]*=nums[i];}Arrays.sort(nums);//排序return nums;}
}
时间复杂度:O(nlog n);(一个for循环为n,再加上排序的nlogn,和为n+nlogn ,取最大的时间复杂度即为nlogn)
空间复杂度:O(1);(没有使用多余空间)
双指针
left指向起始位置,right指向终止位置。定义一个新数组newNums,和A数组一样的大小,根据平方的大小来从数组newNums后往前赋值。
class Solution {public int[] sortedSquares(int[] nums) {int len=nums.length;//数组的长度int left=0; int right=len-1;//双指针int[] newNums=new int[len];//新数组int index=len-1;//新数组赋值的指针while(left<=right){if (nums[left] * nums[left] > nums[right] * nums[right]) {newNums[index]=nums[left]*nums[left];//新数组赋值index--;//新数组指针往前移++left;//起始指针往前移}else{newNums[index]=nums[right]*nums[right];//新数组赋值index--;--right;//结尾指针往后移}}return newNums;}
}
时间复杂度:O(n);(最糟糕的可能就是把数组全遍历一遍,因此为On)
空间复杂度:O(n);(使用多一个数组存值)
Leetcode 209.长度最小的子数组
题目链接:209.长度最小的子数组
大佬视频讲解:209.长度最小的子数组视频讲解
个人思路
一开始又想到暴力解法,但这样明显会超时;然后...就没思路了。(之前刷过好几次滑动窗口还是想不起来,菜得多练呀/无奈)
解法
滑动窗口
滑动窗口就是不断的调节子序列的起始位置和终止位置;
其中主要确定如下三点:
- 窗口的定义;窗口就是 满足其和 ≥
target的长度最小的 连续 子数组。 - 窗口的起始位置如何移动:如果当前窗口的值大于
target了,窗口就要向前移动了(也就是该缩小了)。 - 窗口的结束位置如何移动:窗口的结束位置就是遍历数组的指针,也就是for循环里的索引。
如果还是比较抽象建议看看视频209.长度最小的子数组视频讲解
class Solution {public int minSubArrayLen(int target, int[] nums) {//暴力解法,从头开始遍历,计算达到目标值的张最小连续数组即可;这样会超时int start=0;//滑动窗口的起始位置int sum=0;//滑动窗口的和int answer=Integer.MAX_VALUE;//结果数组长度for(int end=0;end<nums.length;end++){//滑动窗口的结束位置sum+=nums[end];while(sum>=target){answer=Math.min(answer,end-start+1);//用当前滑动窗口的长度与之前长度对比sum-=nums[start++];//不断变更start(子序列的起始位置)}}return answer==Integer.MAX_VALUE ? 0:answer;// 如果说明没有符合条件的子序列,即answer没有被赋值的话,就返回0,}
}
时间复杂度:O(n);(一个 for循环加上一个while没有嵌套,所以是n+n,2n)
空间复杂度:O(1);(没有使用多余空间)
Leetcode 59.螺旋矩阵II
题目链接:59.螺旋矩阵II
大佬视频讲解:59.螺旋矩阵II视频讲解
个人思路
这道题之前做过,没怎么搞懂,只记得是找规律,那先画图看看;画一个n为4和5的数组,螺旋循环后发现规律如下:有四个方向赋值;这四个方向的赋值数量刚刚开始都是n-1;如果n为奇数,则会剩下中间的值没有赋值;循环次数正好是n/2;根据这些规律怎么写代码也是个难题,还得多练


解法
找规律
顺时针画矩阵的过程:
- 上行;从左到右填充数据
- 右列;从上到下填充数据
- 下行;从右到左填充数据
- 左列:从下到上填充数据
由外向内一圈一圈这么画下去。可以发现这里的边界条件非常多,在一个循环中,如此多的边界条件,得按照固定规则来遍历,每画一条边都要坚持一致的左闭右开,或者左开右闭的原则,这样这一圈才能按照统一的规则画下来。
下面的是按照左闭右开规则
class Solution {public int[][] generateMatrix(int n) {int loop = 0; // 控制循环次数int start = 0; // 每次循环的开始点(start, start)int count = 1; // 定义填充数字int[][] res = new int[n][n];//结果数组int i, j;while (loop++ < n / 2) { // 先判断边界后,再自增1,以此循环(n-loop)for (j = start; j < n - loop; j++) {// 上侧从左到右填充数据res[start][j] = count++;}for (i = start; i < n - loop; i++) {// 右侧从上到下填充数据res[i][j] = count++;}for (; j >= loop; j--) {// 下侧从右到左填充数据res[i][j] = count++;}for (; i >= loop; i--) {// 左侧从下到上填充数据res[i][j] = count++;}start++;}if (n % 2 == 1) {//判断n为奇数还是偶数,若为奇数,循环填充后还剩一个中间数没填;res[start][start] = count;}return res;}
}
时间复杂度:O(n^2);(模拟遍历二维矩阵的时间)
空间复杂度:O(1);(没有使用多余空间)
以上是个人的思考反思与总结,若只想根据系列题刷,参考卡哥的网址代码随想录算法官网
相关文章:
算法打卡day2|数组篇|Leetcode 977.有序数组的平方、 209.长度最小的子数组、59.螺旋矩阵II
算法题 Leetcode 977.有序数组的平方 题目链接: 977.有序数组的平方 大佬视频讲解:977.有序数组的平方 个人思路 第一时间就只想到暴力解法,双重循环一个循环比较一个循环赋值;但这样可能会超时,所以还能用双指针࿰…...
Hive【内部表、外部表、临时表、分区表、分桶表】【总结】
目录 Hive的物种表结构特性 一、内部表 建表 使用场景 二、外部表 建表:关键词【EXTERNAL】 场景: 外部表与内部表可互相转换 三、临时表 建表 临时表横向对比编辑 四、分区表 建表:关键字【PARTITIONED BY】 场景: 五、分桶表 …...
随手写的小程序2 一个nc能控制的程序
小程序源代码 下载: https://download.csdn.net/download/nn_84/88846445?spm1001.2014.3001.5501 请下载 Qt 5.12.12 server.pro : QT gui networkCONFIG c11 console CONFIG - app_bundle# You can make your code fail to compile if it uses deprecated APIs. # In o…...
Android中通过属性动画实现文字轮播效果
前些天发现了一个蛮有意思的人工智能学习网站,8个字形容一下"通俗易懂,风趣幽默",感觉非常有意思,忍不住分享一下给大家。 👉点击跳转到教程 一、创建一个自定义ProvinceView类,具体代码如下 /*** Author: ly* Date: 2024/2/22* D…...
最长的回文串
开始想的简单了,确实没想到奇数字母删去一个后也能用 解法: 桶排序 #include<iostream> #include<vector> #include<algorithm> using namespace std; #define endl \n #define int long long signed main() {int t;cin >> t…...
2023 H1 中国边缘公有云服务市场 Top2,百度智能云加速推动分布式云智能化升级
近期,IDC 发布了《中国边缘云市场跟踪研究 2023 H1》。报告显示,2023 上半年,中国边缘公有云服务市场规模 24.3 亿元,同比增速达到 41.8%。 其中,百度智能云以 15.7% 的市场份额位列中国边缘公有云服务市场第二&#…...
Emlog博客网站快速搭建并结合内网穿透实现远程访问本地站点
文章目录 前言1. 网站搭建1.1 Emolog网页下载和安装1.2 网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2.Cpolar稳定隧道(云端设置)2.3.Cpolar稳定隧道(本地设置) 3. 公网访问测试总结 前言 博客作为使…...
力扣经典题目解析--旋转图像(字节二面)
题目 原题地址: . - 力扣(LeetCode) 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。 你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。 示例 1࿱…...
【ARMv8M Cortex-M33 系列 8.1 -- RT-Thread 堆内存 检查命令 free 实现及介绍】
文章目录 RT-Thread 堆内存 检查命令 free 实现及介绍rt_memory_info 函数验证 RT-Thread 堆内存 检查命令 free 实现及介绍 在RT-Thread系统中,通常可以通过rt_memory_info函数获取当前的堆内存使用信息,然后你可以包装这个函数来显示剩余的堆空间。rt…...
milvus Delete API流程源码分析
Delete API执行流程源码解析 milvus版本:v2.3.2 整体架构: Delete 的数据流向: 1.客户端sdk发出Delete API请求。 from pymilvus import (connections,Collection, )print("start connecting to Milvus") connections.connect("default", host"192…...
CentOS使用Docker搭建Halo网站并实现无公网ip远程访问
🔥博客主页: 小羊失眠啦. 🎥系列专栏:《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞👍收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默&…...
【JVM】垃圾回收算法
📝个人主页:五敷有你 🔥系列专栏:JVM ⛺️稳中求进,晒太阳 垃圾回收算法 Java是如何实现垃圾回收的呢?简单来说,垃圾回收就做两件事 找到内存中存活的对象释放不在存活对象的内存&…...
如何和将原始request的Header中的值传递给openfeign请求的Header? 以及又如何获取openfeign请求中Header中的值
如何和将原始request的Header中的值传递给openfeign请求的Header? 以及又如何获取openfeign请求中Header中的值 如何和将原始request的Header中的值传递给openfeign请求的Header参考 [https://www.jb51.net/article/282522.htm](https://www.jb51.net/article/28252…...
Flink 侧输出流(SideOutput)
🌸在平时大部分的 DataStream API 的算子的输出是单一输出,也就是某一种或者说某一类数据流,流向相同的地方。 🌸在处理不同的流中,除了 split 算子,可以将一条流分成多条流,这些流的数据类型也…...
C语言中关于#include的一些小知识
写代码的过程中,因为手误,重复包含了头文件 可以看到没有报错 如果是你自己编写的头文件,那么如果没加唯一包含标识的话,那么编译器会编译报错的。如果是系统自带的头文件,由于其每个头文件都加了特殊标识,…...
DSP芯片 机器码下载方法 【主要 “扯” 用Uniflash下载的方法】
还是以德州仪器的TMS320F28335芯片为 “栗子”,说说这事儿。 编制好的程序经过开发环境可以编译成扩展名为 .out 文件,这个文件就是DSP可以运行机器码,我们把这个文件下载到 DSP芯片中的程序区, 下载好了,这个芯片原…...
速盾网络:CDN用几天关了可以吗?安全吗?
在使用CDN(内容分发网络)时,有时候会考虑暂时关闭或暂停使用CDN服务的情况。但是,对于关闭CDN服务的时间长短以及安全性问题,很多人可能存在疑问。在本文中,我们将讨论CDN使用中关闭几天是否安全以及相关注…...
MR混合现实情景实训教学系统在高空作业课堂中的应用
高空作业是一项高风险的工作,对于从业者来说,不仅需要具备专业的技能,还需要有丰富的实践经验。然而,传统的课堂教学往往只能通过理论讲解和模拟训练来传授知识,无法提供真实的实践环境。而MR混合现实情景实训教学系统…...
Windows系统中定时执行python脚本
背景:本地Windows系统指定目录下会有文件的修改新增,这些变化的文件需要定时的被上传到git仓库中,这样不需要每次变更手动上传了。 首先编写一个检测文件夹下文件变化并且上传git仓库的python脚本(确保你已经在E:\edc_workspace\data_edc_et…...
HashMap 源码学习-jdk1.8
1、一些常量的定义 这里针对MIN_TREEIFY_CAPACITY 这个值进行解释一下。 java8里面,HashMap 的数据结构是数组 (链表或者红黑树),每个数组节点下可能会存在链表和红黑树之间的转换,当同一个索引下面的节点超过8个时…...
对比直接采购与通过Taotoken使用大模型的月度账单差异
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 对比直接采购与通过Taotoken使用大模型的月度账单差异 1. 背景与观察方法 我们是一个小型技术工作室,日常工作需要频繁…...
别再死记硬背One-Hot了!用Python从零实现一个Word2Vec词嵌入模型(附完整代码)
从零构建Word2Vec:用Python实现词嵌入的实战指南 词嵌入技术早已成为自然语言处理的基石,但大多数教程要么停留在理论层面,要么直接调用现成的库函数。本文将带你用纯Python和NumPy从零实现一个Word2Vec模型,彻底掌握词向量生成的…...
别再只当脚本小子了:用ArpSpoof搞懂ARP攻击的底层原理与实战防御
从ArpSpoof实战到协议原理:ARP攻击的深度解析与防御实践 在网络安全领域,ARP攻击是最基础却又最容易被忽视的攻击方式之一。许多初学者能够熟练使用Kali Linux中的ArpSpoof工具发起攻击,却对背后的协议机制知之甚少。这种"知其然而不知其…...
自动同步总失败?NotebookLM本地缓存+云端快照双轨备份,手把手配置到上线仅需7分钟
更多请点击: https://intelliparadigm.com 第一章:NotebookLM数据备份方案 NotebookLM 是 Google 推出的基于用户上传文档进行 AI 助理问答的工具,但其本身不提供原生数据导出或持久化存储功能。为防止项目上下文丢失、模型重置或账户异常导…...
Linux密钥权限检查排查方法
Linux密钥权限检查排查方法本文面向具备一定 Linux 基础的技术人员,围绕密钥权限检查展开,重点讨论授权文件、私钥权限和登录失败。在中级运维和系统管理工作中,这类主题常常与配置变更、资源状态、权限边界、自动化任务和业务影响交织在一起…...
AI Coding 言出法随,未来什么还会值钱?
本文整理自播客《AI炼金术》任鑫(云九资本)与徐文浩的深度对话,探讨 AI Coding 如何重塑个人开发方式、组织形态,以及在生产力极大释放的时代,究竟什么能力还会持续增值。—本文资料通过Ai好记智能解析获取。一、AI Co…...
QGIS二次开发实战:手把手教你用C++ API为矢量点数据实现动态分级渲染(附完整代码)
QGIS二次开发实战:C API实现矢量点数据动态分级渲染 在GIS应用开发中,数据可视化是核心需求之一。当我们需要展示实时传感器数据、业务指标或环境监测数据时,如何让用户一眼看出数值分布和热点区域?分级渲染技术正是解决这一问题的…...
DS18B20单总线温度传感器在CircuitPython中的实战应用指南
1. 项目概述与单总线协议的价值如果你正在用像Adafruit Feather M0 Express或Raspberry Pi Pico这类小巧的板子做项目,需要测量温度,DS18B20绝对是一个绕不开的经典选择。我这些年做过不少环境监测、智能家居的小玩意儿,从鱼缸水温到3D打印机…...
SC4541SKTRT 2MHz 2.9V~22V升/降压单线LED驱动器Semtech电子元器件IC芯片
SC4541SKTRT是Semtech(升特)推出的高频LED驱动器芯片,该器件集升压与降压拓扑于一体,支持2.9V至22V超宽输入电压并具备25V输出电压能力,利用内置肖特基二极管和功率开关,将外部电路减至最少,实现…...
一行环境变量,给 Claude Code 省下 90% 成本
一行环境变量,给 Claude Code 省下 90% 成本 你以为是模型太贵,其实是缓存“漏风”了 🧊💸最近不少开发者发现一个诡异现象: 用了 Claude Code 接国内模型,比如 DeepSeek、Kimi、智谱 AI 后,突然…...
