LeetCode 27. Remove Element

栏目: 编程工具 · 发布时间: 7年前

内容简介:Given an arrayDo not allocate extra space for another array, you must do this byThe order of elements can be changed. It doesn’t matter what you leave beyond the new length.
  • 英文:

Given an array nums and a value val , remove all instances of that value in-place and return the new length.

Do not allocate extra space for another array, you must do this by modifying the input array in-place with O(1) extra memory.

The order of elements can be changed. It doesn’t matter what you leave beyond the new length.

  • 中文:

给定一个数组 nums 和一个值 val ,你需要 原地 移除所有数值等于 val 的元素,返回移除后数组的新长度。

不要使用额外的数组空间,你必须在 原地修改输入数组 并在使用 O(1) 额外空间的条件下完成。

元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

示例

  • 示例 1:
给定 nums = [3,2,2,3], val = 3,

函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。

你不需要考虑数组中超出新长度后面的元素。
  • 示例 2:
给定 nums = [0,1,2,2,3,0,4,2], val = 2,

函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。

注意这五个元素可为任意顺序。

你不需要考虑数组中超出新长度后面的元素。

题解

  • 题解 1

使用两个游标 i 和 j 来遍历数组,如果 第 i 个元素的值等于 val,则使用 j 记录位置,同时递增 i,直到下一个不等于 val 的元素出现,将此时 i 对应的值复制到 j 的位置上,再增加 j ,重复上述过程直到遍历结束。最后,j 就是新数组的长度。

class Solution:
    def removeElement(self, nums, val):
        """
        :type nums: List[int]
        :type val: int
        :rtype: int
        """
        j = 0
        for i in range(len(nums)):  # 遍历数组
            if nums[i] != val:  # 不等于时才记录
                nums[j] = nums[i]  # 复制不等于 val 的值
                j += 1  # 新数组的长度
        return j
  • 题解 2

使用列表的 pop() 方法:

class Solution:
    def removeElement(self, nums, val):
        """
        :type nums: List[int]
        :type val: int
        :rtype: int
        """
        while val in nums:  # 如果列表中还有目标元素
            nums.pop(nums.index(val))  # 移除该元素
        return len(nums)
  • 题解 3

使用 del 语句:

class Solution:
    def removeElement(self, nums, val):
        """
        :type nums: List[int]
        :type val: int
        :rtype: int
        """
        while val in nums:  # 如果列表中还有目标元素
            del nums[nums.index(val)]  # 移除该元素
        return len(nums)
  • 题解 4

使用列表的 remove() 方法(此方法效率最高):

class Solution:
    def removeElement(self, nums, val):
        """
        :type nums: List[int]
        :type val: int
        :rtype: int
        """
        while val in nums:  # 如果列表中还有目标元素
            nums.remove(val)  # 移除该元素
        return len(nums)

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

O2O

O2O

张波 / 机械工业出版社华章公司 / 2013-2-5 / 49.00元

2012年是O2O元年,无论是成熟的传统企业、如火如荼的电子商务企业,还是以电信、银行、娱乐等为代表的与民生相关的企业,都在探索和践行O2O模式,因为O2O中孕育着极富创新性的商业模式。本书是国内首部O2O方面的著作,不仅宏观上叙述了O2O的概念、在各行业的应用情况,以及未来的发展趋势,而且还系统阐述和解读了各行业如何借助O2O来顺利实现商业模式的转型和升级;不仅极富洞察力地分析了O2O在营销、支......一起来看看 《O2O》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具