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

参考资料

相关推荐
liulilittle9 分钟前
回归物理本质:对拥塞控制实验室依赖与公平性误置的反思
网络·tcp/ip·计算机网络·算法·tcp·通信·拥塞控制
牛油果子哥q9 分钟前
unordered_set / unordered_map 底层哈希表精讲,哈希原理、哈希冲突、链地址法、源码结构、有序与无序容器终极选型全解
数据结构·算法·哈希算法·散列表
进击的荆棘13 分钟前
优选算法——优先级队列
数据结构·c++·算法·leetcode·优先级队列
wen_zhufeng13 分钟前
AudioX\-Turbo:面向通用音频生成的高效多模态统一框架
人工智能·算法·音视频
牛油果子哥q22 分钟前
哈希表经典刷题模型与布隆过滤器精讲,哈希查重、哈希计数、双哈希映射、误判原理与工业级落地应用
数据结构·算法·哈希算法·散列表
ruxshui23 分钟前
排序算法及不同场景应用总结
算法·排序算法
旖-旎31 分钟前
《LeetCode 200 FloodFill 岛屿数量DFS解法》
c++·算法·深度优先·力扣·floodfill
拂拉氏33 分钟前
【知识讲解-题目讲解】算法系列之动态规划入门(下)
算法·leetcode·动态规划
skywalk816337 分钟前
继续推进心语项目6.15 @CodeArts
开发语言·算法·编程
2601_9618451537 分钟前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划