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

【数据结构】27.移除元素

在这里插入图片描述

💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤
📃个人主页 :阿然成长日记 👈点击可跳转
📆 个人专栏: 🔹数据结构与算法🔹C语言进阶
🚩 不能则学,不知则问,耻于问人,决无长进
🍭 🍯 🍎 🍏 🍊 🍋 🍒 🍇 🍉 🍓 🍑 🍈 🍌 🍐 🍍

前言

本次博客收录在数据结构栏目中。感兴趣的朋友可以点击上方个人专栏跳转👆

LeetCode–27.移除元素

题目

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

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

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

1️⃣示例 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️⃣示例 2:

输入:nums = [0,1,2,2,3,0,4,2], val = 2 输出:5, nums = [0,1,4,0,3]

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

题解:

1.暴力求解

思路:相对简单易想,相信大多数人第一想法就是暴力求解
就是直接遍历数组,遇到val想等的值,便停下删除元素,并将后面的元素往前移动。

在这里插入图片描述

这种方法相对简单无厘头,就不再写出代码啦。
🕜时间复杂度为O(N^2);
🕜空间复杂度O(N);
📍由于它的时间复杂度实在是太大啦,所以,十分不推荐使用

2.空间换时间

思路:
其实也很简单
🔺1.创建了一个临时变量数组tmp;
🔺2.遍历原数组,判断只要该元素不等于val,那么就存入tmp;
🔺3.将tmp数组拷贝回原来数组;
在这里插入图片描述
时间复杂度为O(N)
空间复杂度为O(N)

3.双指针法(最好的方法)

思路:
使用两个指针front,end
🔸1️⃣ 开始向后遍历,如果遇到不等于val的值那么,将nums[end]赋值给nums[front];
🔸2️⃣遇到等于val的值,则end直接++跳过;
🔸3️⃣最终,end+1就是数组删除过后的元素个数。
![在这里插入图片描述](https://img-blog.csdnimg.cn/19b7875062504bbaa23c1263f8aeeb38.png

int removeElement(int* nums, int numsSize, int val){int front = 0;int end = 0;while(end<numsSize){if(nums[end]!=val){nums[front++] = nums[end++];}else{end++;}}return front;
}

在这里插入图片描述
可见这种方法的效率非常高。
时间复杂度为O(N)
空间复杂度为O(1)

http://www.lryc.cn/news/99879.html

相关文章:

  • 机器学习分布式框架ray运行xgboost实例
  • C++设计模式笔记
  • 简单聊聊创新与创造力
  • 使用TensorFlow训练深度学习模型实战(上)
  • 【Spring】什么是Bean的生命周期及作用域,什么是Spring的执行流程?
  • 立创EDA学习
  • 清风学习笔记—层次分析法—matlab对判断矩阵的一致性检验
  • 大众安徽内推
  • Meta “地平线世界”移动端应用即将上线,手机快乐元宇宙?
  • 更省更快更安全的云服务器,一站式集中管理,随时随地远程——站斧云桌面
  • 出现 Try run Maven import with -U flag (force update snapshots) 的解决方法
  • python多线程
  • Spring Framework 提供缓存管理器Caffeine
  • ZQC的游戏 题解
  • 24考研数据结构-第一章 绪论
  • Gitlab 备份与恢复
  • 数据库—用户权限管理(三十三)
  • C语言【怎么定义变量?】
  • vue中使用vab-magnifier实现放大镜效果
  • 无涯教程-jQuery - Highlight方法函数
  • 【bar堆叠图形绘制】
  • ORACLE数据库灾难恢复
  • base和正则备份
  • ArcGIS Engine 与 Visual Studio版本对照表
  • JPA连接达梦数据库导致auto-ddl失效问题解决
  • 【MATLAB第60期】【更新中】基于MATLAB的ARMAX具有外生回归因子的移动平均自回归模型
  • Vue 常用指令 v-on 自定义参数,事件修饰符
  • 重要通知|关于JumpServer开源堡垒机V2版本产品生命周期的相关说明
  • 下载快 kaggle output
  • 结构型设计模式-1.代理设计模式