顺序表算法 - 移除元素

. - 力扣(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;
}
相关推荐
铭哥的编程日记3 分钟前
小企鹅装石头(栈模拟题)
算法
汉堡go4 分钟前
SLAM数学基础1
人工智能·算法·机器学习
汉克老师5 分钟前
GESP 四级C++考试2025年3月第二部分判断题(1-10题)
数据结构·c++·排序算法·指针·结构体·gesp4级·gesp四级
qzhqbb5 分钟前
不可检测水印
人工智能·算法
快敲啊死鬼6 分钟前
机试day5
算法·华为od·华为
8Qi88 分钟前
LeetCode热题100--189
c语言·数据结构·c++·算法·leetcode
灰色小旋风8 分钟前
力扣第八题C++ 字符串转换整数
c++·算法·leetcode
进击的雷神10 分钟前
请求频率限制、嵌套数据结构、多目录聚合、地址字段重构——K展爬虫四大技术难关攻克纪实
数据结构·爬虫·python·重构
@––––––10 分钟前
力扣hot100—系列9—图论
算法·leetcode·图论
pp起床12 分钟前
图论 | part01
算法·深度优先·图论