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

文章来源:

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

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

相关推荐
hetao17338379 分钟前
2025-11-13~14 hetao1733837的刷题记录
c++·算法
N 年 后10 分钟前
单独Docker部署和Docker Compose部署
java·docker·容器
hansang_IR19 分钟前
【题解】洛谷 P2476 [SCOI2008] 着色方案 [记搜]
c++·算法·记忆化搜索
lkbhua莱克瓦2421 分钟前
Java练习——数组练习
java·开发语言·笔记·github·学习方法
趙卋傑22 分钟前
常见排序算法
java·算法·排序算法
Slow菜鸟28 分钟前
Java后端常用技术选型 |(四)微服务篇
java·分布式
武子康34 分钟前
Java-168 Neo4j CQL 实战:WHERE、DELETE/DETACH、SET、排序与分页
java·开发语言·数据库·python·sql·nosql·neo4j
Filotimo_35 分钟前
SpringBoot3入门
java·spring boot·后端
天地之于壹炁兮42 分钟前
元素认证的智慧:Python分支魔法的艺术与禁忌
windows·python
通往曙光的路上1 小时前
SpringIOC-注解
java·开发语言