今天在学校监考校招(赚点零花钱,低保和劳务一月没发了,哎),继续刷题吧!~
今天再和车神哥一起来提升自己的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,一点已不为过吧~