算法每日一题 —— 27.移除元素

我们有一个算法刷题群,每周群主会安排 4 道题,节假日没题目。想要一起刷题的小伙伴可以加我微信 zzh0838

题目描述

所有解法均在无参考情况下手写,机打了一遍:

暴力法

cpp 复制代码
    int removeElement(vector<int> &nums, int val) {
        int size = nums.size();
        for (int i = 0; i < size; ++i) {
            if (nums[i] == val) {
                for (int j = i; j < size - 1; ++j) {
                    nums[j] = nums[j + 1];
                }
                i--;
                size--;
            }
        }
        return size;
    }

双指针法

cpp 复制代码
int removeElement(vector<int>& nums, int val) {
    int slow = 0;
    int fast = 0;
    int size = nums.size();
    for(fast = 0; fast < size; fast++) {
        if(nums[fast] != val) {
            nums[slow] = nums[fast];
            slow++;
        } 
    }

    return slow;
}

双指针优化

cpp 复制代码
int removeElement(vector<int>& nums, int val) {
    int left = 0, right = nums.size() - 1;
    while(left < right) {
        if(nums[left] == val) {
            num[left] = nums[right];
            right--;
        } else {
            left++;
        }
    }

    return left;
}

参考资料

相关推荐
_ziva_2 分钟前
YOLO 目标检测算法深度解析:从原理到实战价值
算法·yolo·目标检测
Jason_Honey219 分钟前
【蚂蚁金服Agent算法岗一面】
人工智能·算法·自然语言处理·面试
weixin_4772716922 分钟前
《老子》一书作者“李耳”简介
算法·图搜索算法
智算菩萨22 分钟前
交错多模态内容生成:从“单张图“到“图文混排长文“的创作范式变革
人工智能·算法·aigc
Flying pigs~~25 分钟前
机器学习之KNN算法
算法·机器学习·大模型·knn·k近邻算法·大数据处理
Navigator_Z35 分钟前
LeetCode //C - 962. Maximum Width Ramp
c语言·算法·leetcode
m0_6727033136 分钟前
上机练习第29天
算法
兩尛37 分钟前
409. 最长回文串
c++·算法·leetcode
(❁´◡`❁)Jimmy(❁´◡`❁)39 分钟前
【KMP】算法详解
算法
智者知已应修善业1 小时前
【pta反转加法构造回文数c语言1000位】2025-1-31
c语言·c++·经验分享·笔记·算法