顺序表算法 - 移除元素

. - 力扣(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;
}
相关推荐
记忆多5 分钟前
c++名字空间 函数模版 左右值
开发语言·c++·算法
三伏52210 分钟前
控制理论前置知识——相平面数学基础2(示例部分)
算法·平面·控制
2401_889884661 小时前
高性能计算通信库
开发语言·c++·算法
郝YH是人间理想1 小时前
Pandas库DataFrame数据结构
数据结构·pandas
不想看见4041 小时前
Hamming Distance位运算基础问题--力扣101算法题解笔记
算法
像污秽一样1 小时前
算法与设计与分析-习题4.1
算法·链表·排序算法
竹烟淮雨2 小时前
C语言指针概念详解:数组指针与二级指针的本质区别
c语言
lhc200906252 小时前
【作业】 贪心算法
算法·贪心算法
天若有情6732 小时前
循环条件隐藏陷阱:我发现了「同循环双条件竞态问题」
c++·学习·算法·编程范式·while循环··竞态
j_xxx404_2 小时前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode