<LeetCode天梯>Day005 旋转数组 (切片法) | 初级算法 | Python

举报
府学路18号车神 发表于 2022/04/11 15:21:51 2022/04/11
【摘要】 今天再和车神哥一起来提升自己的Python编程和面试能力吧,刷天梯~以下为我的天梯积分规则:每日至少一题:一题积分+10分 若多做了一题,则当日积分+20分(+10+10)若做了三道以上,则从第三题开始算+20分(如:做了三道题则积分-10+10+20=40;做了四道题则积分–10+10+20+20=60)初始分为100分若差一天没做题,则扣积分-10分(周六、周日除外注:休息)坚持!!! ...

今天再和车神哥一起来提升自己的Python编程和面试能力吧,刷天梯~

以下为我的天梯积分规则

每日至少一题:一题积分+10分
若多做了一题,则当日积分+20分(+10+10)
若做了三道以上,则从第三题开始算+20分(如:做了三道题则积分-10+10+20=40;做了四道题则积分–10+10+20+20=60


初始分为100分
若差一天没做题,则扣积分-10分(周六、周日除外注:休息
坚持!!!


初级算法

刷题目录

数组

在这里插入图片描述

题干

给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。

进阶版:

  • 尽可能想出更多的解决方案,至少有三种不同的方法可以解决这个问题。
  • 你可以使用空间复杂度为 O(1) 的 原地 算法解决这个问题吗?

示例1:

输入: nums = [1,2,3,4,5,6,7], k = 3
输出: [5,6,7,1,2,3,4]
解释:
向右旋转 1 步: [7,1,2,3,4,5,6]
向右旋转 2 步: [6,7,1,2,3,4,5]
向右旋转 3 步: [5,6,7,1,2,3,4]

示例2:

输入:nums = [-1,-100,3,99], k = 2
输出:[3,99,-1,-100]
解释:
向右旋转 1 步: [99,-1,-100,3]
向右旋转 2 步: [3,99,-1,-100]


分析:

我这里想到的是用冒泡的思想,一个一个的往后移动,但是超出了时间范围,运行是可以运行的。

class Solution:
    def rotate(self, nums: List[int], k: int) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        n = len(nums)
        while k > 0:
            k -= 1
            for i in range(n-1, 0, -1):
                nums[i-1], nums[i] = nums[i], nums[i-1]

遇到最后几个超大型的数组时,会戎机,超出时间限制。

然后咱们再优化优化一下看看:

是否可以用对数组的切片来实现旋转,切片成两部分,然后再反过来拼接起来,其实就一句

nums[:] = nums[n-k:] + nums[:n-k]

然鹅,发现自己还是太年轻了,没有考虑到,如果数组数少于移动次数,那么就会不满足上述情况,所以就不能做切片。

我们再优化优化,用nums的个数个K的数取余数,看是否k大于len(nums),咱们再加一条判断试试

class Solution:
    def rotate(self, nums: List[int], k: int) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        n = len(nums)
     
        kk = k % n # 取余数
        nums[:] = nums[n-kk:] + nums[:n-kk]

在这里插入图片描述
效果虽然不是最好,但是Python说是yyds,一点已不为过吧~
在这里插入图片描述
在这里插入图片描述
然后又想到了另一个方法,咱们在下一节更新多次翻转

1024,不加班不加班不加班,节日快乐xdm!!!~❤

Reference

作者:力扣 (LeetCode)
链接:https://leetcode-cn.com/leetbook/read/top-interview-questions-easy/x2skh7/
来源:力扣(LeetCode)


今日得分:+20
总得分:160(1024节,就加Double份吧~)

加油!!!

❤坚持读Paper,坚持做笔记,坚持学习❤!!!
再加个坚持刷题!!!打天梯!!!
To Be No.1

⚡⚡


创作不易⚡,过路能❤关注收藏点个赞三连就最好不过了

ღ( ´・ᴗ・` )


信心这个东西,什么时候都像个高楼大厦,但是里面会长白蚁。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。