算法每日一题 —— 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;
}

参考资料

相关推荐
naturerun14 小时前
螺旋形遍历奇数阶矩阵
c++·算法·矩阵
wuweijianlove14 小时前
算法复杂度的实验估算与误差分布建模的技术7
算法
佳xuan15 小时前
简而言之c++
c++·算法
变量未定义~15 小时前
星际争霸、宝石塔的亮度差异、寻找食物储量
算法
YL2004042615 小时前
027合并两个有序链表
java·数据结构·算法·链表
MATLAB代码顾问16 小时前
【智能优化】无穷优化算法(INFO)原理与Python实现
开发语言·python·算法
炽烈小老头16 小时前
【每天学习一点算法 2026/05/10】合并K个排序链表
学习·算法·链表
SilentSamsara16 小时前
迭代器协议:`__iter__` / `__next__` 的完整执行流程
开发语言·人工智能·python·算法·机器学习
AI科技星16 小时前
算法联盟ROOT · 全域数学物理卷第20、21、22分册:量子纠缠、隐形场论与时间膨胀
人工智能·算法·数学建模·数据挖掘·机器人
MATLAB代码顾问16 小时前
【智能优化】鹈鹕优化算法(POA)原理与Python实现
开发语言·python·算法