顺序表算法 - 移除元素

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/remove-element/description/思路:

代码:

cpp 复制代码
// numsSize表示数组的长度
int removeElement(int* nums, int numsSize, int val) {
    int src = 0;
    int dest = 0;
    //src小于数组的时候进入循环
    while (src < numsSize) 
    {
        //nums[src]是否等于vcal
        if (nums[src] == val) 
        {
            src++;
        } 
        else
        {
            //先赋值,后自增
            nums[dest++] = nums[src++];
        }
    }
    //此时det指向的位置就是要返回的有效个数
    return dest;
}

运行结果:

从上面的代码我们可以看出不管nums[src]是否等于val,dest都要++,那么我们的代码就可以优化一下。

cpp 复制代码
// numsSize表示数组的长度
int removeElement(int* nums, int numsSize, int val) {
    int src = 0;
    int dest = 0;
    //src小于数组的时候进入循环
    while (src < numsSize) 
    {
        //nums[src]是否等于vcal
        if (nums[src] != val) 
        {
            nums[dest] = nums[src];
            dest++;
        } 
        src++;
    }
    //此时det指向的位置就是要返回的有效个数
    return dest;
}
相关推荐
进击的小头40 分钟前
行为型模式:策略模式的C语言实战指南
c语言·开发语言·策略模式
探序基因1 小时前
单细胞Seurat数据结构修改分群信息
数据结构
六义义1 小时前
java基础十二
java·数据结构·算法
四维碎片1 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs1 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
爱编码的小八嘎2 小时前
C语言对话-5.通过任何其他名字
c语言
独自破碎E2 小时前
【优先级队列】主持人调度(二)
算法
weixin_445476682 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王2 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展
Swift社区3 小时前
LeetCode 385 迷你语法分析器
算法·leetcode·职场和发展