程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长

+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

2023-06(1)

python(leetcode)-283移动零

发布于2019-08-07 16:21     阅读(643)     评论(0)     点赞(1)     收藏(4)


给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

示例:

输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:

必须在原数组上操作,不能拷贝额外的数组。
尽量减少操作次数。

 说下拿到这道题时的思路:

给人的感觉并不难,首先的想法就是遍历数组中每一个元素,判断如果为0则删除,同时末尾增加0

上代码(通过240ms)击败20%的用户

 1 class Solution:
 2     def moveZeroes(self, nums):
 3         """
 4         :type nums: List[int]
 5         :rtype: void Do not return anything, modify nums in-place instead.
 6         """
 7         for i in nums:
 8             if(i==0):
 9                 nums.remove(i)
10                 nums.append(0)
11         
12 
13 if __name__=="__main__":
14     s=Solution()
15     nums=[0,1,0,3,12]
16     print(s.moveZeroes(nums))

代码非常简洁,只有短短4行,但是对比其他方法效率却不高,

分析代码的时间复杂度

外层for循环需要N次,remove(i)需要N次,append()方法1次

所以时间复杂度为O(n^2)

 

换一种方法,上代码(通过) 56ms 击败99%

 1 class Solution:
 2     def moveZeroes(self,nums):
 3         """
 4 
 5         :param nums:
 6         :return:
 7         """
 8         count=0
 9         zero=0
10         for i in range(len(nums)):
11             if(nums[i]!=0):           #判断是否为0
12                 nums[count]=nums[i]   #不是0的数向前移
13                 count+=1              #移动一个 计数加一
14             else:
15                 zero+=1
16         for j in range(count,len(nums)): #把最后位置补0
17             nums[j]=0
18         return nums
19 if __name__=="__main__":
20     s=Solution()
21     nums=[0,1,0,3,12]
22     print(s.moveZeroes(nums))

 思路在代码中有注释

分析下时间复杂度:

for循环有N次,if语句1次,赋值语句1次,++1次

第二个for循环N次,赋值语句1次

两个for循环是并列关系 所以时间复杂度为O(n) 可以发现确实速度快了很多



所属网站分类: 技术文章 > 博客

作者:fhue34873

链接:https://www.pythonheidong.com/blog/article/11506/43170ad95898350ba17c/

来源:python黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

1 0
收藏该文
已收藏

评论内容:(最多支持255个字符)