算法:轮转数组---循环取模运算

文章来源:

https://blog.csdn.net/weixin_45630258/article/details/132729961

欢迎各位大佬指点、三连

1、题目:

给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。

2、分析特点:

  • 轮转 ==> 取模运算

  • 我们可以使用额外的数组来将每个元素放至正确的位置。用 n 表示数组的长度,我们遍历原数组,将原数组下标为 i 的元素放至新数组下标为 (i+k) mod n 的位置,最后将新数组拷贝至原数组即可。

3、代码:

4、复杂度分析:

  • 时间复杂度: O(n),其中 n 为数组的长度。
  • 空间复杂度: O(n)。

5、总结:

轮转、循环 k 步,要想到取模运算,另外需要一个新数组作为结果数组是因为如果我们不使用额外数组,我们直接将每个数字放至它最后的位置,这样被放置位置的元素会被覆盖从而丢失,所以需要一个新数组作为结果数组,最后拷贝回去原数组。

如果本文对你有帮助的话记得给一乐点个赞哦,感谢!

相关推荐
記億揺晃着的那天4 分钟前
SpringCloud从零开始简单搭建 - JDK17
java·spring boot·后端·spring cloud·nacos
little redcap4 分钟前
KMP整理+个人推导+快速上手理解
数据结构·笔记·算法
蠢蠢的打码11 分钟前
8587 行编辑程序
数据结构·c++·算法·链表
EPSDA13 分钟前
Java集合(三)
java·开发语言
m0_6177753915 分钟前
代码随想录训练营第34天| 62.不同路径 、63. 不同路径 II
数据结构·算法·图论
DC102016 分钟前
Java 每日一刊(第14期):抽象类和接口
java·开发语言
憨憨憨憨憨到不行的程序员16 分钟前
Spring框架基础知识
java·后端·spring
农大蕉蕉19 分钟前
C++校招面经(二)
java·开发语言·c++
维生素C++23 分钟前
【可变模板参数】
linux·服务器·c语言·前端·数据结构·c++·算法
尘埃不入你眼眸26 分钟前
递归快速获取机构树型图
java·服务器·windows