leetcode27. 移除元素

目录

问题描述

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。

假设 nums 中不等于 val 的元素数量为 k,要通过此题,您需要执行以下操作:

  • 更改 nums 数组,使 nums 的前 k 个元素包含不等于 val 的元素。nums 的其余元素和 nums 的大小并不重要。
  • 返回 k。

题目链接:移除数组

示例


提示

0 <= nums.length <= 100

0 <= nums[i] <= 50

0 <= val <= 100

具体思路

思路一

从前往后进行查找,当数组中的值等于val的时候,将数组后面的值依次往前进行挪动。算法的时间复杂度为O( N 2 N^2 N2),空间复杂度为O(1)

思路二

采用时间换空间的方法,另外开辟一个新的数组,将原来数组中不等于val的值放到新的数组中去,最后再拷贝回原来的数组。算法的时间复杂度为O(N),空间复杂度为O(N)。

思路三

采用双指针的方法,定义src和dst的指针,当数组中元素的值等于val的时候,src往后面走,不等于val的时候i,就将src中的值放到dst中算法的时间复杂度为O(N),空间复杂度为O(1)

代码实现

cpp 复制代码
//思路3
int removeElement(int* nums, int numsSize, int val) {
    int src=0;
    int dst =0;
    while(src<numsSize)
    {
        if(nums[src]!=val)
        {
            nums[dst++]=nums[src++];
        }
        else
        {
            src++;
        }
    }
    return dst;
}
相关推荐
vyuvyucd5 分钟前
Java数组与Arrays类实战指南
数据结构·算法
山上三树6 分钟前
详细介绍 C 语言中的匿名结构体
c语言·开发语言·算法
EXtreme357 分钟前
【数据结构】彻底搞懂二叉树:四种遍历逻辑、经典OJ题与递归性能全解析
c语言·数据结构·算法·二叉树·递归
山上三树14 分钟前
详细介绍 C 语言 typedef 及与 #define 的核心对比
c语言·数据结构·算法
集芯微电科技有限公司18 分钟前
替代HT6310/KP3310离线式AC-DC无感线性稳压器
数据结构·人工智能·单片机·嵌入式硬件·fpga开发
yuanmenghao40 分钟前
CAN系列 — (8) 为什么 Radar Object List 不适合“直接走 CAN 信号”
网络·数据结构·单片机·嵌入式硬件·自动驾驶·信息与通信
一条大祥脚1 小时前
26.1.3 快速幂+容斥 树上dp+快速幂 带前缀和的快速幂 正序转倒序 子序列自动机 线段树维护滑窗
数据结构·算法
2301_780669861 小时前
List(特有方法、遍历方式、ArrayList底层原理、LinkedList底层原理,二者区别)
java·数据结构·后端·list
꧁Q༒ོγ꧂1 小时前
算法详解(四)--排序与离散化
数据结构·算法·排序算法
王老师青少年编程1 小时前
信奥赛C++提高组csp-s之二分图
数据结构·c++·二分图·csp·信奥赛·csp-s·提高组