苹果就叫不呐呐 2022-10-15 21:28 采纳率: 0%
浏览 11

leedcode轮转数组问题

leedcode问题
class Solution:
    def rotate(self, nums: List[int], k: int) -> None:
        k = k % len(nums)
        if(k==0|len(nums)==1): 
            return 
        nums1 = nums[len(nums)-k:len(nums):1]
        nums2 = [item for item in nums if item not in nums1]
        nums = nums1+nums2


运行结果及报错内容

无法得出正确结果,求指教

img

我想要达到的结果

输出[5,6,7,1,2,3,4]

  • 写回答

1条回答 默认 最新

  • 请叫我问哥 Python领域新星创作者 2022-10-15 21:57
    关注

    这题是要“就地”改变列表,你这里生成了一个新的列表,所以旧的列表并未发生改变
    我是这样解的:

    class Solution:
        def rotate(self, nums: List[int], k: int) -> None:
            k %= len(nums)
            k = len(nums)-k
            nums += nums[:k]
            nums[:k]=list()
    
    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 10月15日

悬赏问题

  • ¥20 python忆阻器数字识别
  • ¥15 无法输出helloworld
  • ¥15 高通uboot 打印ubi init err 22
  • ¥20 PDF元数据中的XMP媒体管理属性
  • ¥15 R语言中lasso回归报错
  • ¥15 网站突然不能访问了,上午还好好的
  • ¥15 有没有dl可以帮弄”我去图书馆”秒选道具和积分
  • ¥15 semrush,SEO,内嵌网站,api
  • ¥15 Stata:为什么reghdfe后的因变量没有被发现识别啊
  • ¥15 振荡电路,ADS仿真