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

文章来源:

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

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

相关推荐
wengqidaifeng8 小时前
数据结构(三)栈和队列(下)队列:程序世界的秩序之美
数据结构
努力学算法的蒟蒻8 小时前
day84(2.12)——leetcode面试经典150
算法·leetcode·面试
程序员酥皮蛋8 小时前
hot 100 第二十三题 23.反转链表
数据结构·算法·leetcode·链表
像少年啦飞驰点、8 小时前
零基础入门 RabbitMQ:从消息队列是什么到 Spring Boot 实战收发消息
java·spring boot·微服务·消息队列·rabbitmq·异步编程
v***57008 小时前
SpringBoot项目集成ONLYOFFICE
java·spring boot·后端
阿萨德528号8 小时前
Spring Boot实战:从零构建企业级用户中心系统(八)- 总结与最佳实践
java·spring boot·后端
TracyCoder1238 小时前
LeetCode Hot100(51/100)——155. 最小栈
数据结构·算法·leetcode
爱上妖精的尾巴8 小时前
8-8 WPS JS宏 正则表达式 字符组与任选
java·服务器·前端
wu_asia8 小时前
每日一练叁
算法