【leetcode面试经典150题】-27. 移除元素

88.合并两个有序数组

  • 1 题目介绍
  • 1 个人解题思路
    • 1.1 解题代码
    • 1.2 思路解析
  • 2、分析官方题解
    • 2.1 单侧双指针
    • 2.2 双侧双指针


1 题目介绍

在这里插入图片描述

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

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

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

1 个人解题思路

1.1 解题代码

class Solution {public int removeElement(int[] nums, int val) {int not_val_nums=0;if(nums.length==0){return nums.length;}for(int i=0;i<nums.length;i++){if(nums[i]!=val){not_val_nums++;}}int length=0;int def_length=nums.length;while(length<def_length){if(nums[length]==val){for(int j=length;j<nums.length-1;j++){nums[j]=nums[j+1];}def_length--;}else{length++;if(length==not_val_nums){break;}}}return length;}
}

1.2 思路解析

  • 首先遍历一遍,统计不等于val的数的个数not_val_nums
  • 然后开始遍历,如果等于val,那么就把每个之后的数付给前面的数。然后因为覆盖了一个数,也就是移除了一个数,那么实际上数组的长度是减一的。
  • 如果不等于val,那就往后走。直到走到等于最开始统计的数not_val_nums退出
    在这里插入图片描述

2、分析官方题解

2.1 单侧双指针

class Solution {public int removeElement(int[] nums, int val) {int n = nums.length;int left = 0;for (int right = 0; right < n; right++) {if (nums[right] != val) {nums[left] = nums[right];left++;}}return left;}
}

指针都在同一侧,如果右指针负责遍历,左指针交换,如果右指针等于val,就跳过,如果不等于val,那就把右指针的数移到左指针,然后左指针++,等待下一次交换。
挺巧妙地,我本来也想写成这个的,奈何脑子没转过来。

2.2 双侧双指针

class Solution {public int removeElement(int[] nums, int val) {int left = 0;int right = nums.length;while (left < right) {if (nums[left] == val) {nums[left] = nums[right - 1];right--;} else {left++;}}return left;}
}

这个我一看名字我就知道怎么解了,左右各一个指针,如果左指针等于val,那就把右指针的数付给左指针,右指针向左移动,否则左指针向右移动。
这个太巧妙了,我怎么就没想到

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

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

相关文章

Linux之函数应用实例--加法器

一、创建一个对2个整数求和的加法器 首先&#xff0c;定义了一个名为 adder 的 Bash 函数&#xff0c;该函数接受两个参数 $1 和 $2 并输出它们的和。 function adder { echo $[ $1$2 ] } 注意&#xff1a; function 关键字是可选的。在 Bash 中&#xff0c;可以简单地使…

算法练习day4

前言 中间个人原因断了很久&#xff0c;现在回来继续。。。。 两两交换链表中的节点 代码随想录 两两交换链表中的节点 24. 两两交换链表中的节点 - 力扣&#xff08;LeetCode&#xff09; &#xff08;用时&#xff1a;0.3小时&#xff09; 思路 这道题的思路其实很简单…

IDEA 每次启动都显示选择项目页面

IDEA版本&#xff1a;2021.3.3 打开 Settings > Appearance & Behavior > System Settings 取消勾选 Reopen projects on startup 然后下次启动 IDEA 会显示选择项目页面

立创EDA绘制PCB电路板

1、绘制好原理图后&#xff0c;点击设计---原理图转PCB&#xff0c;生成PCB文件 2、将元器件拖入电路板方框内&#xff0c;摆放布局并使用工具栏布线、放置过孔及丝印 3、然后顶层和底层铺铜 4、后面就可以生成制板文件发送嘉立创制板了。

Python实行任意文件的加密—解密

Python实行任意文件的加密—解密 环 境&#xff1a; 系统&#xff1a;macOS Sonoma IDE&#xff1a;PyCharm 2024 Professional Edition 源代码如下&#xff1a; from cryptography.fernet import Fernet import os# 定义一个加密类 class Encrypt:# 参数是需要被加密的文…

Excel 每 N 列内容填成一行

Excel表格从第 2 列起&#xff0c;每 N 列为一组&#xff0c;以 N2 为例&#xff1a; ABCDEFG1IDType 1Count 1Type 2Count 2Type 3Count 321a640d290a32d12000a1900f600043f48000f3600e160054c46000e3100b120065e47000c3400d140076b64000b3600c1200 现在要进列转行&#xff…

听劝!普通人千万别随意入门网络安全

一、什么是网络安全 网络安全是一种综合性的概念&#xff0c;涵盖了保护计算机系统、网络基础设施和数据免受未经授权的访问、攻击、损害或盗窃的一系列措施和技术。经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全运维”…

002_Anaconda的安装与使用

Python的开发环境 官方介绍&#xff1a;Anaconda&#xff0c;中文大蟒蛇&#xff0c;是一个开源的Python发行版本&#xff0c;其包含了conda、Python等180多个科学包及其依赖项。 比较抽象&#xff0c;看不懂没有关系&#xff0c;慢慢往下看。 很多学习python的初学者甚至学…

【STL】string

本节博客主要是介绍了一下CPP标准库中的string这一容器的相关用法和常用接口&#xff0c;有需要借鉴即可。 目录 1.string介绍1.1CPP标准库与STL关系1.2string历史问题与介绍 2.string概要3.Member functions3.1constructor3.2operator 4.访问4.1[]访问4.2迭代器访问4.3范围for…

istio资源字段参考文档

virtual service&#xff1a; Istio / Virtual ServiceConfiguration affecting label/content routing, sni routing, etc.https://istio.io/latest/docs/reference/config/networking/virtual-service/

5---Linux小程序“进度条”及缓冲区的概念(逻辑梳理,轻松理解)

一、缓冲区的解析&#xff1a; 1.1论点的引入&#xff1a; 在Linux中有一个接口sleep&#xff0c;可以使得C/C程序休眠一段指定的时间。他需要依赖的头文件是<unistd.h>&#xff0c;注意这个接口为Linux私有。 usleep接口类似sleep接口&#xff0c;但是单位为微秒。下面…

MES系统追溯管理功能,迅速定位问题源头

一、MES系统概述 MES系统是一种实现车间生产智能化、信息化的管理系统&#xff0c;通过对生产现场的数据进行实时采集、处理和分析&#xff0c;为企业管理者提供准确、及时的生产信息。MES系统主要包括生产订单管理、物料追溯、质量管理、设备管理、物料管理、人员管理等功能模…