算法day01_ 27. 移除元素、977.有序数组的平方

推荐阅读

从零开始学数组:深入浅出,带你掌握核心要点
初探二分法
再探二分法


系统的纪录一下刷算法的过程,之前一直断断续续的刷题,半途而废,现在重新开始。话不多说,开冲!

27.移除元素

题目

给你一个数组 nums_ 和一个值 val,你需要 原地 移除所有数值等于 val _的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地修改输入数组
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

说明:
为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以**「引用」**方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。
你可以想象内部操作如下:

// nums 是以“引用”方式传递的。也就是说,不对实参作任何拷贝
int len = removeElement(nums, val);// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中 该长度范围内 的所有元素。
for (int i = 0; i < len; i++) {print(nums[i]);
}

image.png

思路

暴力解法主要是两层for循环,一层for循环找到val,一层for循环用于覆盖val,将val后的所有的数组元素全部前移。

-1516976305.jpg

双指针法主要是通过一个快指针和慢指针在一个for循环下完成两个for循环的工作。

  • 快指针用于寻找新数组元素的值
  • 慢指针用于来确定新数组元素的下标

283705997.jpg

解法

暴力解法

代码实现

class Solution {public int removeElement(int[] nums, int val) {int length=nums.length;for(int i=0; i<length;i++){if(nums[i]==val){for(int j=i+1;j<length;j++){nums[j-1]=nums[j];}i--;length--;}}return length;}
}
  • 时间复杂度:O(n^2)
  • 空间复杂度:O(1)

快慢指针解法

代码实现

class Solution {public int removeElement(int[] nums, int val) {int slowIndex=0;for(int fastIndex=0;fastIndex<nums.length;fastIndex++){if(nums[fastIndex]!=val){nums[slowIndex]=nums[fastIndex];slowIndex++;}}return slowIndex;}
}
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

977.有序数组的平方

题目

给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。

image.png

思路

该题目中给的序列为非递减序列,即有可重复值的递增序列。
暴力解法、快慢指针法都是先平方后排序。
双指针法,使用start下标和end下标进行指向,并将元素平方后的大小判断的结果填入新的数组,在新数组中,从后往前依次填入数组元素。

  • 若 nums[startIndex]*nums[startIndex]<nums[endIndex]*nums[endIndex],那么result[k–]=nums[endIndex]*nums[endIndex];
  • 若nums[startIndex]*nums[startIndex]>nums[endIndex]*nums[endIndex],那么 result[k–]=nums[startIndex]*nums[startIndex];

144100158.jpg

解法

暴力解法

代码示例:

class Solution {public int[] sortedSquares(int[] nums) {int[] newNums=new int[nums.length];for(int i=0;i<nums.length;i++){newNums[i]=nums[i]*nums[i];}Arrays.sort(newNums);return newNums;}
}
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)
快慢指针法

代码示例:

class Solution {public int[] sortedSquares(int[] nums) {int fastIndex=0;int slowIndex=0;for(fastIndex=0;fastIndex<nums.length;fastIndex++){nums[slowIndex]=nums[fastIndex]*nums[fastIndex];slowIndex++;}Arrays.sort(nums);return nums;}
}
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)
双指针法

代码示例

class Solution {public int[] sortedSquares(int[] nums) {int[] result=new int[nums.length];int k=nums.length-1;int startIndex=0;int endIndex=nums.length-1;while(startIndex<=endIndex){if(nums[startIndex]*nums[startIndex]<nums[endIndex]*nums[endIndex]){result[k--]=nums[endIndex]*nums[endIndex];endIndex--;}else{result[k--]=nums[startIndex]*nums[startIndex];startIndex++;}}return result;}
}
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

js 面试 什么是WebSockets?HTTP和HTTPS有什么不同?web worker是什么?

概念&#xff1a; webSocket 是一种在客户端和服务端之间建立持久连接的协议&#xff0c;它提供全双工通信通道&#xff0c;是服务器可以主动向客户端推送数据&#xff0c;同时也可以接受客户端发送的数据。 1 webSocket与https区别&#xff1f; 在网络通信中&#xff0c;We…

Acceptor监听套接字管理类实现(模块七)

目录 类功能 类定义 类实现 编译测试 类功能 类定义 // 监听套接字管理类 class Acceptor { private:Socket _socket; // 用于创建监听套接字EventLoop *_loop; // 用于对监听套接字进行事件监控Channel _channel; // 用于对监控套接字进行事件管理using AcceptCallback…

11 PLL IP核

PLL IP 核简介 锁相环&#xff08;PLL&#xff09;作为一种反馈控制电路&#xff0c;其特点是利用外部输入的参考信号来控制环路内部震荡信号的频率和相位。因为锁相环可以实现输出信号频率对输入信号频率的自动跟踪&#xff0c;所以锁相环通常用于闭环跟踪电路。锁相环在工作…

36.云原生之SpringCloud+k8s实践

云原生专栏大纲 文章目录 SpringCloudk8s介绍spring-cloud-kubernetes服务发现配置管理负载均衡选主 spring-cloud-bookinfo案例构建项目环境配置namespace部署与验证productpagegatewaybookinfo-admindetailsratingsreviewsreviews-v1reviews-v2 总结 SpringCloudk8s介绍 ht…

React UI框架Antd 以及 如何按需引入css样式配置(以及过程中各种错误处理方案)

一、react UI框架Antd使用 1.下载模块 npm install antd -S 2.引入antd的样式 import ../node_modules/antd/dist/reset.css; 3.局部使用antd组件 import {Button, Calendar} from antd; import {PieChartTwoTone} from ant-design/icons; {/* 组件汉化配置 */} import l…

SORA 到底是什么?如何用bitget wallet购买?

什么是SORA&#xff1f; SORA 是一种模因币&#xff0c;灵感来自 OpenAI 最新的人工智能模型 Sora&#xff0c;它巧妙地根据文本输入生成视频。 SORA 诞生于加密社区内人工智能项目的热潮中&#xff0c;利用 OpenAI 的公告推出了一种独特且时尚的数字资产。正如 memecoin 网站…

【管理咨询宝藏资料28】某信息技术有限公司战略规划报告

本报告首发于公号“管理咨询宝藏”&#xff0c;如需阅读完整版报告内容&#xff0c;请查阅公号“管理咨询宝藏”。 【管理咨询宝藏资料28】某信息技术有限公司战略规划报告 【关键词】战略规划、对标研究、管理咨询 【文件核心观点】 - 使企业实现商业流程整合&#xff0c;构…

宏集小型PLC应用于浮动封盖机

导言 仅通过1个控制面板和1个紧凑型PLC控制自动化设备中来自不同制造商的13种不同电机&#xff0c;听起来难以置信&#xff01;但这是宏集科技已经落地的合作项目&#xff01; 案例概况 客户&#xff1a;TREPAK 合作伙伴&#xff1a;SDT 应用&#xff1a;封盖机 应用产品&…

UE5 UE4 自定义插件自动开启关联插件(plugin enable)

在我们自己编写UE4、UE5的插件时&#xff0c;常常需要开启相关联的插件进行功能编写。 例如&#xff1a;UE4/5 批量进行贴图Texture压缩、修改饱和度_ue4批量修改纹理大小-CSDN博客 而让插件使用者每次使用时&#xff0c;依次进行开启其他相关联插件确实有些麻烦。 如何只需要…

【数据结构】数组

第一章、为什么数组的下标一般从0开始编号 提到数组&#xff0c;读者肯定不陌生&#xff0c;甚至还会很自信地说&#xff0c;数组很简单。编程语言中一般会有数组这种数据类型。不过&#xff0c;它不仅是编程语言中的一种数据类型&#xff0c;还是基础的数据结构。尽管数组看起…

js 面试 http 与 https, 长连接,http状态码,哪三次握手,在浏览器地址栏键入URL回车之后过程?

1 概念 http是超文本传输协议&#xff0c;信息明文传输。 https是安全超文本传输协议, 以安全为目标的HTTP通道,在HTTP的基础上通过身份认证和传输加密阶段保证了传输过程的安全性. https:主要是增加了TLS&#xff08;Transport Layer Security 安全传输层协议&#xff09;/…

超声波清洗机对眼镜有伤害吗?警惕清洗眼镜禁忌!

近年来&#xff0c;随着人们对健康生活要求的提升&#xff0c;超声波清洗机在市场上的受欢迎程度逐渐攀升&#xff0c;产品的多样性也让人眼花缭乱。近期收到了大量读者的一些私信&#xff0c;其中很多人询问使用超声波清洗机会对眼镜有伤害吗、超声波清洗机是不是智商税、超声…

如何使用Docker部署WBO容器并实现固定公网地址访问本地白板界面

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&…

【Git教程】(六)分支合并 —— 合并过程,各类合并冲突及解决思路 ~

Git教程 分支 1️⃣ 合并过程中发生的事2️⃣ 冲突3️⃣ 编辑冲突4️⃣ 冲突标志5️⃣ 解决编辑冲突6️⃣ 内容冲突7️⃣ 快进合并8️⃣ 第一父级提交历史9️⃣ 棘手的合并冲突&#x1f33e; 总结 使用 merge 命令来进行分支合并是 Git 中最重要的操作之一。虽然这一操作的底层…

Window10安装ruby

最好的方法&#xff0c;使用rubyinstaller&#xff0c;即在Downloads。 这是官方推荐的安装方式 通常来说我们会下载64位的 下载完后执行下载的exe即可。在最后一步会提示让安装gem&#xff0c;选则安装即可。 然后就可以在控制台进行测试了。

UE蓝图 宏(Macro)节点和源码

系列文章目录 UE蓝图 Get节点和源码 UE蓝图 Set节点和源码 UE蓝图 Cast节点和源码 UE蓝图 分支(Branch)节点和源码 UE蓝图 入口(FunctionEntry)节点和源码 UE蓝图 返回结果(FunctionResult)节点和源码 UE蓝图 函数调用(CallFunction)节点和源码 UE蓝图 序列(Sequence)节点和源…

JWT基于Cookie的会话保持,并解决CSRF问题的方案

使用JWT进行浏览器接口请求&#xff0c;在使用Cookie进行会话保持传递Token时&#xff0c;可能会存在 CSRF 漏洞问题&#xff0c;同时也要避免在产生XSS漏洞时泄漏Token问题&#xff0c;如下图在尽可能避免CSRF和保护Token方面设计了方案。 要点解释如下&#xff1a; 将JWT存入…

PclSharp--计算AABB包围盒体积2

一、AABB包围盒 AABB包围盒即轴对齐包围盒&#xff0c;就是包围盒对齐坐标轴。计算相对简单&#xff0c;在要求不精细的情况下&#xff0c;这种包围盒是够用的。 MomentOfInertiaEstimation 是 PCL中的一个类&#xff0c;用于计算点云中物体的矩。它可以提供点云物体的三个主…

【HarmonyOS】鸿蒙开发之Video组件——第3.7章

Video组件内VideoOptions属性简介 src&#xff1a;设置视频地址。currentProgressRate&#xff1a;设置视频播放倍速&#xff0c;参数说明如下&#xff1a; number|string&#xff1a;只支持 0.75 &#xff0c; 1.0 &#xff0c; 1.25 &#xff0c; 1.75 &#xff0c; 2.0 。P…

IDEA利用鼠标调整字体大小

就可以按住ctrl和鼠标调节代码字体的大小啦&#xff01; 如果有用&#xff0c;记得给我来个赞~ 谢啦&#xff01;