当前位置: 首页 > news >正文

(LeetCode 面试经典 150 题) 27.移除元素

目录

题目:

题目描述:

题目链接:

思路:

核心思路:

思路详解:

样例模拟:

代码:

C++代码:

Java代码:


题目:

题目描述:

题目链接:

27. 移除元素 - 力扣(LeetCode)

思路:

核心思路:

双指针

思路详解:

我们先按最容易理解的思路:定义两个指针i,j,i指针指向第一个元素,j指针指向最后一个元素。我们要遍历数组中所有的元素进行换位调整,所以编译完全部元素的条件是两个指针交错(即i>j)。在while语句中,判断i指向的元素是否等于val,如果不等于那么不用调整直接跳过,即i指针后移。如果i指向的元素等于val,那么我们将i指向的元素和j指向的元素对调。此时换到i上的元素是否等于val我们不知道,所以要到下一轮再判断,但是此时换到j上的元素一定等于val,所以j指针前移。

到最后的i索引一定是最后一个不等于val元素的后一位,所以最后一个不等于val元素的索引为i-1,即一共有i个不等于val的元素。由题要返回不等于val元素的个数,所以返回i。

上述是最容易理解且详细的思路,由题我们其实只需要保证最后nums的前k个元素是不等于val的元素,nums其余元素和nums大小不重要。所以我们不需要i与j指向元素互换,只需要把j指向元素换到i就行了

样例模拟:

代码:

C++代码:

class Solution {
public:int removeElement(vector<int>& nums, int val) {int i = 0;                //i指针指向第一个元素int j = nums.size() - 1;  //j指针指向最后一个元素//int temp;while(i <= j)  //当两个指针交错时表示全部元素已经遍历完了{if(nums[i] != val){i++;  //如果i指向的元素不等于val直接跳过,i指针后移}else{//temp = nums[i];nums[i] = nums[j];  //如果i指向的元素等于val,与j指向的元素进行交换//nums[j] = temp;j--;  //那么此时j指向的一定是换过来等于val的值,j指针前移}}return i;  //由题返回不等于val的元素数量}
};

Java代码:

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

相关文章:

  • Spring Boot:运用Redis统计用户在线数量
  • 百度AIP:Springboot人脸对比
  • 【钓鱼预警】针对跨境销售投递Tesla间谍木马
  • <tauri><threejs><rust><GUI>基于tauri和threejs,实现一个3D图形浏览程序
  • 初探 Nacos 原理
  • Qt/C++开发监控GB28181系统/rtp解包/jrtplib库的使用/同时支持udp和tcp被动和主动三种方式解包
  • 日志技术-Logback入门程序
  • 初见语音识别(ASR)
  • 通过审计日志分析和摘要利用大型语言模型进行网络攻击检测
  • K8S: etcdserver: too many requests
  • 2025 年前端框架的深度解析与展望
  • 微服务(nacos+myibatis)中如何在一个模块调用多数据库源的一种方案
  • 矩阵阶数(线性代数) vs. 张量维度(深度学习):线性代数与深度学习的基石辨析,再也不会被矩阵阶数给混淆了
  • 对kotti_image项目进行pytest测试操作实践(失败)
  • Camera Sensor接口协议全解析(四)LVDS与SubLVDS接口及协议深度解析
  • 【第二章:机器学习与神经网络概述】03.类算法理论与实践-(1)逻辑回归(Logistic Regression)
  • 108页精品PPT | 大型某著名企业能源行业数字化转型汇报方案能源化工数字化转型
  • Java基础(三):逻辑运算符详解
  • 阿里云Elasticsearch生产环境误删数据恢复指南
  • LabVIEW网络流通信介绍
  • 小程序定制开发中软/抖音seo教程
  • 高端做网站价格/百度旗下所有app列表
  • 网站建设分金手指专业二七/必应搜索引擎地址
  • 建设网站开题报告/建站模板免费下载
  • 云南哪有网站建设报价的/百度问一问官网
  • WordPress资讯站点源码/seo推广有哪些