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

解法性能:

解法分析:

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

相关推荐
不会计算机的捞地5 分钟前
【数据结构入门训练DAY-30】数的划分
数据结构·算法·深度优先
八股文领域大手子15 分钟前
Java死锁排查:线上救火实战指南
java·开发语言·面试
Code_流苏18 分钟前
《Python星球日记》 第71天:命名实体识别(NER)与关系抽取
python·深度学习·ner·预训练语言模型·关系抽取·统计机器学习·标注方式
点云SLAM19 分钟前
Python中列表(list)知识详解(2)和注意事项以及应用示例
开发语言·人工智能·python·python学习·数据结果·list数据结果
国强_dev19 分钟前
任意复杂度的 JSON 数据转换为多个结构化的 Pandas DataFrame 表格
开发语言·python
伊织code43 分钟前
PyTorch API 7 - TorchScript、hub、矩阵、打包、profile
人工智能·pytorch·python·ai·矩阵·api
开开心心就好1 小时前
高效全能PDF工具,支持OCR识别
java·前端·python·pdf·ocr·maven·jetty
XQ丶YTY1 小时前
大二java第一面小厂(挂)
java·开发语言·笔记·学习·面试
The_cute_cat1 小时前
试除法判断素数优化【C语言】
算法