【LeetCode】27. 移除元素(简单)——代码随想录算法训练营第1天

题目描述

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。

不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。

元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

说明:

为什么返回数值是整数,但输出的答案是数组呢?

请注意,输入数组是以「引用」方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。

你可以想象内部操作如下:

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

示例 1:

输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2]
解释:函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。你不需要考虑数组中超出新长度后面的元素。例如,函数返回的新长度为 2 ,而 nums = [2,2,3,3] 或 nums = [2,2,0,0],也会被视作正确答案。

示例 2:

输入:nums = [0,1,2,2,3,0,4,2], val = 2
输出:5, nums = [0,1,3,0,4]
解释:函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。注意这五个元素可为任意顺序。你不需要考虑数组中超出新长度后面的元素。

提示:

0 <= nums.length <= 100
0 <= nums[i] <= 50
0 <= val <= 100

文章讲解:代码随想录

视频讲解:数组中移除元素并不容易! | LeetCode:27. 移除元素_哔哩哔哩_bilibili

 

题解1:暴力法

思路:用一个变量记录当前遍历的位置,用一个新变量查找下一个非目标值的位置,将用此值前移覆盖要删除的元素。

/*** @param {number[]} nums* @param {number} val* @return {number}*/
var removeElement = function(nums, val) {let i = j = 0;// 变量 i 记录当前检索位置,变量 j 查找下一个非目标值的位置while (i < nums.length) {if (nums[i] === val) {// 遇到要删除的元素,查找下一个不需要删除的元素的位置j = i + 1;while (nums[j] === val) {j++;}if (j === nums.length) {return i; // 查找到数组末尾,返回 i}nums[i] = nums[j]; // 将不删除的元素前移覆盖要删除的元素nums[j] = val; // 将 j 位置标记为要删除元素的位置}i++;}return i; // 查找结束,返回 i
};

分析:此解法用了双层循环,j 变量重复遍历了多次数组,时间复杂度为 O(n²),空间复杂度为 O(1)。存在不必要的消耗,可以使用快慢指针法来优化。

题解2:快慢指针法

定义快慢指针:

  • 快指针:寻找新数组的元素 ,新数组就是不含有目标元素的数组
  • 慢指针:指向更新新数组下标的位置
/*** @param {number[]} nums* @param {number} val* @return {number}*/
var removeElement = function(nums, val) {let i = 0; // 慢指针,记录当前位置for (let j = 0; j < nums.length; j++) {// 快指针,查找下一个非目标值if (nums[j] !== val) {nums[i++] = nums[j]; // 将非目标值前移,且慢指针自增}}return i; // 返回慢指针位置,即为移除元素后新数组元素的个数
};

分析:使用双指针法,只需遍历一次数组,时间复杂度为 O(n),空间复杂度为 O(1)。此方法没有改变原数组元素的顺序。

题解3:相向双指针法

思路:题目中提到元素顺序可以改变,因此可以使用相向双指针法从数组的两边来遍历数组。左边寻找等于目标值的元素,右边寻找不为目标值的元素,交换位置得到新数组。

/*** @param {number[]} nums* @param {number} val* @return {number}*/
var removeElement = function(nums, val) {let left = 0, right = nums.length - 1;while (left <= right) {// 从左边找等于 val 的元素while (left <= right && nums[left] !== val) {left++;}// 从右边找不等于 val 的元素while (left <= right && nums[right] === val) {right--;}// 右边覆盖左边if (left < right) {nums[left++] = nums[right--];}}return left; // left 此时是新数组最后一个元素的下一个位置,即为新数组长度
};

分析:使用相向双指针法,只需遍历一次数组,时间复杂度为 O(n),空间复杂度为 O(1)。此方法改变了原数组元素的顺序。

收获

初次体验了快慢指针法和相向双指针法这两种双指针法的使用,并理解了它们的原理。

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

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

相关文章

R语言【base】——sample():随机取样和排列

Package base version 4.2.0 Description sample() 使用替换或不替换从参数【x】的元素中获取指定大小的样本。 Usage sample(x, size, replace FALSE, prob NULL)sample.int(n, size n, replace FALSE, prob NULL,useHash (n > 1e07 && !replace &&…

20240110在ubuntu20.04下重启samba服务

20240110在ubuntu20.04下重启samba服务 百度搜索&#xff1a;samba restart https://www.python100.com/html/78028.html 重启samba命令详解 更新&#xff1a;2023-05-17 16:04 一、重启samba命令 重启samba可以使用以下命令&#xff1a; /etc/init.d/smb restart 或者 syste…

中国智造闪耀CES | 木牛科技在美国CES展亮相多领域毫米波雷达尖端方案

素有全球科技潮流“风向标”之称的2024国际消费类电子产品展&#xff08;CES&#xff09;&#xff0c;于1月9-12日在美国拉斯维加斯会议中心举办。CES是全球最大的消费电子和消费技术展览会之一&#xff0c;汇集了世界各地优秀的消费电子和科技公司&#xff0c;带着最好的产品来…

uniapp项目怎么删除顶部导航栏

uniapp去掉顶部导航的方法&#xff1a; 1、去掉所有导航栏 "globalStyle": { "navigationBarTextStyle": "white", "navigationBarTitleText": "uni-app", "navigationBarBackgroundColor": "#007AFF"…

Apache ActiveMQ RCE CNVD-2023-69477 CVE-2023-46604

漏洞简介 Apache ActiveMQ官方发布新版本&#xff0c;修复了一个远程代码执行漏洞&#xff0c;攻击者可构造恶意请求通过Apache ActiveMQ的61616端口发送恶意数据导致远程代码执行&#xff0c;从而完全控制Apache ActiveMQ服务器。 影响版本 Apache ActiveMQ 5.18.0 before 5.1…

Windows系统下python版本Open3D-0.18.0 的快速安装与使用

目录 一、安装Anaconda3二、安装open3d三、测试代码四、结果展示五、测试数据 Windows系统下python版本Open3D-0.18.0 的快速安装与使用由CSDN点云侠原创&#xff0c;爬虫自重。如果你不是在点云侠的博客中看到该文章&#xff0c;那么此处便是不要脸的爬虫。 一、安装Anaconda…

Hive基础知识(八):Hive对数据库的增删改查操作

1. 创建数据库 CREATE DATABASE [IF NOT EXISTS] database_name [COMMENT database_comment]#注释 [LOCATION hdfs_path]#指定当前库的hdfs目录 [WITH DBPROPERTIES (property_nameproperty_value,...)]; #备注创建作者和创建时间 1&#xff09;创建一个数据库&#xff0c;数据…

【机器学习300问】2、机器学习分为哪几类?

一、监督学习 监督学习&#xff08;Supervised Learning&#xff09;是机器学习和人工智能中的一种算法学习训练方式。它利用有标签的数据&#xff08;通常称为训练数据&#xff09;作为输入&#xff0c;训练一个模型来学习输入和输出之间的关系。模型学习后可以用于预测新的、…

Linux 常用进阶指令

我是南城余&#xff01;阿里云开发者平台专家博士证书获得者&#xff01; 欢迎关注我的博客&#xff01;一同成长&#xff01; 一名从事运维开发的worker&#xff0c;记录分享学习。 专注于AI&#xff0c;运维开发&#xff0c;windows Linux 系统领域的分享&#xff01; 其他…

华为机试真题实战应用【赛题代码篇】-快递投放问题(附Java和C++代码实现)

目录 问题描述 解题思路 代码实现 Java 代码2 C++ 问题描述 有N个快递站点用字符串标识,某些站点之间有道路连接。每个站点有一些包裹要运输,每个站点间的包裹不重复, 路上有检查站会导致部分货物无法通行

SQL语句中EXISTS的终极指南

SQL语句中EXISTS的终极指南 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天&#xff0c;我们将深入探讨在SQL语句中经常用到的一项强大工具——“EXISTS”&#…

最实用的 8 个免费 Android 数据恢复软件

如果您正在寻找最好的免费 Android 数据恢复软件&#xff0c;那就不用再犹豫了&#xff0c;因为我已经列出了最好的软件。不可否认&#xff0c;智能手机和平板电脑等 Android 设备正在与技术一起发展。与以前相比&#xff0c;它们也更加融入了我们的日常生活。 Android 智能手…

Vue3-45-Pinia-定义全局状态的两种方式

Pinia 的作用介绍 Pinia 是管理 全局状态的工具。 全局状态 &#xff1a; 我的理解&#xff0c;就是一个全局的变量&#xff0c;在项目内&#xff0c;所有的组件都可以使用它&#xff0c;对它进行读写操作。 全局状态的三个核心概念 state : 最核心的&#xff0c;就是变量的定义…

Golang,Gin框架使用ShouldBindJSON时出现EOF报错

前言 做毕设ing&#xff0c;使用的是Gin框架做的一个简单的管理系统。但偶尔也会碰到一些稀奇古怪的Bug&#xff0c;因此记录一下。 问题描述 api是这样写的 func UserRegisterHandler(c *gin.Context, user *usecase.UserOperate) {if err : c.ShouldBindJSON(&UserReg…

七种查找算法,十大排序算法

文章目录 常见的七种查找算法&#xff1a;1. 基本查找2. 二分查找3. 插值查找4. 斐波那契查找5. 分块查找6. 哈希查找7. 树表查找 十大排序算法&#xff1a;1. 冒泡排序1.1 算法步骤1.2 动图演示1.3 代码示例 2. 选择排序2.1 算法步骤2.2 动图演示 3. 插入排序3.1 算法步骤3.2 …

数据结构与算法教程,数据结构C语言版教程!(第三部分、栈(Stack)和队列(Queue)详解)三

第三部分、栈(Stack)和队列(Queue)详解 栈和队列&#xff0c;严格意义上来说&#xff0c;也属于线性表&#xff0c;因为它们也都用于存储逻辑关系为 "一对一" 的数据&#xff0c;但由于它们比较特殊&#xff0c;因此将其单独作为一章&#xff0c;做重点讲解。 使用栈…

2022-2023 ICPC, Asia Yokohama Regional Contest 2022(题解)

2022-2023 ICPC, Asia Yokohama Regional Contest 2022 文章目录 A. Hasty Santa ClausB. Interactive Number GuessingC. Secure the Top SecretD. Move One CoinE. Incredibly Cute Penguin ChicksF. Make a LoopG. Remodeling the DungeonH. Cake DecorationI. Quiz Contest…

企业微信与CRM集成(AI问答)

企业微信&#xff0c;自建应用&#xff0c;和企业已有的crm系统&#xff0c;能够怎样结合起来&#xff0c;请给出建议 企业微信与自建应用以及现有的CRM系统相结合&#xff0c;可以通过以下几种方式来提升客户关系管理效率和内部协作水平&#xff1a; API集成&#xff1a; 利用…

【申请SSL证书】免费申请阿里云SSL证书

注意&#xff1a;申请 SSL证书的前提是有一个域名且备案了 第一部&#xff1a;申请免费证书 免费 CA 证书购买地址&#xff08;请戳这里&#xff09; 选择合适的选项如下图 为了解决免费证书近期存在的吊销、统计等问题&#xff0c;自2021年起&#xff0c;免费证书申请申请将…

鸿蒙Harmony--状态管理器--@Prop详解

纵横千里独行客&#xff0c;何惧前路雨潇潇。夜半浊酒慰寂寞&#xff0c;天明走马入红尘。且将新火试新茶&#xff0c;诗酒趁年华。青春以末&#xff0c;壮志照旧&#xff0c;生活以悟&#xff0c;前路未明。时间善变&#xff0c;可执着翻不了篇。时光磨我少年心&#xff0c;却…