【数据结构OJ题】移除元素

原题链接:https://leetcode.cn/problems/remove-element/

目录

1. 题目描述

2. 思路分析

3. 代码实现


1. 题目描述

2. 思路分析

方法一:暴力删除,挪动数据覆盖。即遍历整个nums[ ]数组,遇到值等于val的元素,就将整个元素后面的所有元素都向左挪动一位。

时间复杂度:O(N^2)

空间复杂度:O(1)

方法二时间换空间。额外开辟一个tmp[ ]数组。定义两个变量src和dst,src遍历nums[]数组,dst最开始指向tmp[ ]的最开始位置。将src位置不等于val的值插入到dst位置,然后再把tmp[ ]数组拷贝回去。

流程演示:

 

 时间复杂度:O(N)

空间复杂度:O(N)

方法三:和方法二类似,但是直接在原数组操作。定义两个变量src和dst,src遍历nums[]数组,dst最开始指向nums[ ]的最开始位置。将src位置不等于val的值插入到dst位置。(也就是src在nums[ ]数组找不是val的值依次尾插

我们也把这种算法叫双指针算法

流程演示:

 

 时间复杂度:O(N)

 空间复杂度:O(1)

我们发现通过双指针算法大大优化了时间复杂度和空间复杂度!

3. 代码实现

我们这里进行时间复杂度和空间复杂度最优的方法三的代码实现:

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

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值