LeetCode详解之如何一步步优化到最佳解法:27. 移除元素

LeetCode详解系列的总目录(持续更新中):

LeetCode详解之如何一步步优化到最佳解法:前100题目录(更新中...)-CSDN博客

LeetCode详解系列的上一题链接:

LeetCode详解之如何一步步优化到最佳解法:26. 删除有序数组中的重复项-CSDN博客

目录

LeetCode详解系列的总目录(持续更新中):

LeetCode详解系列的上一题链接:

[27. 移除元素](#27. 移除元素)

解法:最终版

解法思路:

代码:

解法性能:

解法分析:


27. 移除元素

本题题目链接: 27. 移除元素 - 力扣(LeetCode)

解法:最终版

解法思路:

首先,题目的要求中,下面的点很重要:

根据上面的提示,我们只需要确保将nums中与val不同的元素放到nums的前k个位置即可。我们可以用"快慢指针"的思路来解这道题。即,"慢指针"指明不等于val的元素有多少个;"快指针"遍历nums数组。

当"快指针"遍历nums数组时,遇到不等于val的元素,则将该元素放到"慢指针"所指向的位置,且"慢指针"向后移一位。

对应的代码如下所示:

代码:

python 复制代码
class Solution:
    def removeElement(self, nums: List[int], val: int) -> int:
        slow_pt = 0
        for num in nums:
            if num != val:
                nums[slow_pt] = num
                slow_pt += 1
        
        return slow_pt

解法性能:

解法分析:

使用该方法,不论是消耗的时间,还是消耗的空间,都是较优的。

相关推荐
数据智能老司机30 分钟前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
闰五月2 小时前
JavaScript作用域与作用域链详解
前端·面试
数据智能老司机2 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机2 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机2 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
CoovallyAIHub2 小时前
港大&字节重磅发布DanceGRPO:突破视觉生成RLHF瓶颈,多项任务性能提升超180%!
深度学习·算法·计算机视觉
顾林海2 小时前
Android编译插桩之AspectJ:让代码像特工一样悄悄干活
android·面试·性能优化
poemyang2 小时前
技术圈的“绯闻女孩”:Gossip是如何把八卦秘密传遍全网的?
后端·面试·架构
c8i2 小时前
drf初步梳理
python·django
每日AI新事件2 小时前
python的异步函数
python