【力扣100】189.轮转数组

添加链接描述

python 复制代码
class Solution:
    def rotate(self, nums: List[int], k: int) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        # 思路:三次数组翻转
        n=len(nums)
        k=k%n
        nums[:] = nums[-k:] + nums[:-k]
        

思路就是:

  1. 事实上就是数组的三次翻转
  2. 这里nums[-k:]的意思是从倒数第k个元素到末位
  3. nums[:-k]的意思是从首位到-k个元素(不包含第-k个元素)
  4. nums[:]是为了在原表上操作,如果是nums=...就不是在原表上操作
  5. 如果使用nums = nums[-k:] + nums[:-k]:就是创建了一个新的nums,并改变原nums的引用(你后面的nums会覆盖原来的nums,通过id(nums)可以看出来)

这里再写几种python中翻转的操作

1. reverse()

这个函数会对原列表进行操作,并且只对列表操作

2. reversed()

这个函数不会对原列表操作,并且可以对除了列表之外还有元组,字符串等

3. 切片操作

list[start : end][ : : -1]对列表进行操作,但跟ed一样,不会对原列表进行操作

相关推荐
生成论实验室5 分钟前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》导论:在破碎的世界寻找统一语法
人工智能·科技·算法·架构·创业创新
承渊政道5 分钟前
【动态规划算法】(两个数组的DP问题深度剖析与求解方法)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
杨连江9 分钟前
原子级平面限域协同晶核诱导定向生长单层鳞片石墨的研究
算法
MATLAB代码顾问15 分钟前
混合粒子群-模拟退火算法(HPSO-SA)求解作业车间调度问题——附MATLAB代码
算法·matlab·模拟退火算法
Felven19 分钟前
C. Prefix Min and Suffix Max
算法
加农炮手Jinx20 分钟前
LeetCode 26. Remove Duplicates from Sorted Array 题解
算法·leetcode·力扣
加农炮手Jinx20 分钟前
LeetCode 88. Merge Sorted Array 题解
算法·leetcode·力扣
格林威20 分钟前
线阵工业相机:如何计算线阵相机的行频(Line Rate)?公式+实例
开发语言·人工智能·数码相机·算法·计算机视觉·工业相机·线阵相机
yueyue54323 分钟前
透过现象看本质:以fast_lio架构的整套算法的局部避障改为TEB算法为例深度探讨——如何成为一个合格的算法架构师?
算法·架构
梨花爱跨境23 分钟前
红人视频×A10算法:亚马逊转化率与流量闭环实战
算法