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

参考资料

相关推荐
shizhenshide10 分钟前
极速响应:平均破解速度<3秒的验证码服务,为抢购爬虫而生
算法
AD钙奶-lalala11 分钟前
leetcode核心母题总结
算法·leetcode·职场和发展
努力学算法的蒟蒻26 分钟前
day53(1.4)——leetcode面试经典150
算法·leetcode·面试
leiming629 分钟前
c++ transform算法
开发语言·c++·算法
裴云飞40 分钟前
Compose原理一之快照系统
算法·架构
橘颂TA41 分钟前
【剑斩OFFER】哈希表简介
数据结构·算法·散列表
小尧嵌入式41 分钟前
c++红黑树及B树B+树
开发语言·数据结构·c++·windows·b树·算法·排序算法
tobias.b1 小时前
408真题解析-2009-10-数据结构-排序
数据结构·算法·排序算法·408考研·408真题·真题解析
Zachary_zlc1 小时前
有向无环图检测算法和关键路径算法
算法
你撅嘴真丑1 小时前
素数回文数的个数 与 求分数序列和
算法