小白理解python中remove与del 的区别


leetcode中的题目,感觉之前不太理解,就记录下来了。

题目:移动零,给定一个数组 nums, 编写一个函数将所有 0 移动到它的末尾,同时保持非零元素的相对顺序(Python3 环境)。

例如:

  1. 必须在原数组上操作,不要为一个新数组分配额外空间。
  2. 尽量减少操作总数

1、在编写程序过程中,首先想到了remove函数:

class Solution(object):
    def moveZeroes(self, nums):
        for i in range(len(nums)):
            if nums[i]==0:
                nums.remove(nums[i])
                nums.append(0)
        return nums
A=Solution()
print(A.moveZeroes([1,0,0,3]))

结果是对的[1,3,0,0]

2、后面又想到了del函数

class Solution(object):
    def moveZeroes(self, nums):
        for i in range(len(nums)):
            if nums[i]==0:
                del (nums[i])
                nums.append(0)
        return nums
A=Solution()
print(A.moveZeroes([1,0,0,3]))

结果是错误的:[1,0,3,0]

3、之前没有深究过这两个函数的区别,在这突然想深究一下。

按我们的正常思维考虑一下上面两个程序,给定列表nums=[1,0,0,3],在for循环中,当i=0时,不作处理;

当i=1时,此时nums[1]=0,删除nums[1]=0,然后在末尾再添加一个0 ,nums变为nums=[1,0,3,0];

当i=2时,此时nums[2]=3,不作任何处理;

当i=3时,此时nums[3]=0,删除nums[3]=0,然后在末尾再添加一个0 ,nums变为nums=[1,0,3,0];

由此可以看出,我们所考虑的最后结果和del函数的处理是一样的,那么remove函数为什么不一样呢?

原因是:

(1)remove删除的是首次出现在列表中的元素。在第一个程序中,当i=3时,nums=[1,0,3,0],nums[3]=0,

当执行这一句 nums.remove(nums[3]) 操作时,会首先找到列表中第一次出现的0,将其删掉。

(2)而del删除的就是那个索引的元素。在第二个程序中,当i=3时,nums=[1,0,3,0],nums[3]=0,

当执行这一句 nums.remove(nums[3]) 操作时,会将nums[3]在索引3这个位置的元素删掉。

4、对于第二个程序的调试:

class Solution(object):
    def moveZeroes(self, nums):
        index=0
        for i in range(len(nums)):
            if nums[index]==0:
                del (nums[index])
                nums.append(0)
            else:
                index+=1
        return nums
A=Solution()
print(A.moveZeroes([1,0,0,3]))

注意:i只是对操作次数的循环,在循环中完全可以不用。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM