LeetCode 027 Remove Element

本文介绍了一种高效的数组元素删除算法,通过使用双指针技术来减少写入次数,特别是当要删除的元素较少时,该算法能有效提高效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目要求把数组里等于某数的项都删掉。注意题目里说数组里的数字顺序可以变化。

当要删掉的数字在原数组里很少的时候,如何保证写入次数最少?我们保留两个指针(或iterator)i和j,i指向当前可以覆盖的位置,即要删掉的数所在位置;j指向当前从末尾开始第一个非需要删掉的数字的位置,每次交换i和j的内容即可。

int removeElement(vector<int>& nums, int val) {
        if(nums.size() == 0)
            return 0;

        auto i = nums.begin();
        auto j = nums.end() - 1;
        while(j != i && *j == val) j--;

        if(*j == val) return 0;
        else if(i == j) return 1;

        while(i < j) {
            while(i < j && *i != val) i++;
            swap(*i, *j);
            i++;
            while(i < j && *j == val) j--;
        }
        while(i != nums.end() && *i != val) i++;
        return i - nums.begin();
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值