27. Remove Element

题目:Remove Element

Given an array and a value, remove all instances of that value in place and return the new length.

Do not allocate extra space for another array, you must do this in place with constant memory.

The order of elements can be changed. It doesn't matter what you leave beyond the new length.

Example:
Given input array nums = [3,2,2,3], val = 3

Your function should return length = 2, with the first two elements ofnums being 2.


解法一:

维护一个表示“下一个交换位置”的指针ex,初始为-1。遍历数组,当找到第一个elem的位置时,将ex指向他,

然后程序要做的就是在遍历过程中检查ex是否存在,存在的话就把当前数挪到ex处,同时把ex向前移动一位。
但是要注意一点是,当再次遇到elem时ex是不更新的。(也就是ex只是在elem第一次出现的时候为其赋值,然后就只用递增他就行了)


代码:

int removeElement(int* nums, int numsSize, int val) {
    
    if(numsSize==0)return 0;
    
    int length=numsSize;
    int sub=-1;
    for(int i=0;i<numsSize;i++)
    {
        if(nums[i]==val)
        {
            length--;
            if(sub<0)
            {
                sub=i;
            }
        }
        else
        {
            if(sub>=0)
                nums[sub++]=nums[i];
        }
        
    }
    return length;
    
}



解法二:

认真观察删除操作的性质会发现,删除一个元素不过就是把他后面的元素向前移动一位,那删除两个不就是移动两位,三个就是三位。。。以此类推。

所以我们只用在遍历数组的时候跟踪删除的个数n,然后同时将元素向后挪动n位就可以了,就这么简单。

代码:

int removeElement(int* nums, int numsSize, int val) {
    
    int length=0;
    for(int i=0;i<numsSize;i++)
    {
        if(nums[i]==val)
        {
            length++;
        }
        else
        {
            nums[i-length]=nums[i];
        }
    }
    return numsSize-length;
}

解法三:

给定下标start,就是只要不是等于要删除的元素,就直接进行复制。


代码:

int removeElement(int* nums, int numsSize, int val) {
    
    int start=0;
    for(int i=0;i<numsSize;i++)
    {
        if(nums[i]!=val)
        {
            nums[start++]=nums[i];
        }
    }
    return start;
}












  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值