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

文章来源:

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

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

相关推荐
D.....l几秒前
冒泡排序与选择排序以及单链表与双链表
数据结构·算法·排序算法
欧阳天风1 分钟前
链表运用到响应式中
javascript·数据结构·链表
代码不停12 分钟前
MySQL联合查询
java·数据库·mysql
nightunderblackcat14 分钟前
新手向:C语言、Java、Python 的选择与未来指南
java·c语言·python
纯真时光17 分钟前
Maven高级
java
sinat_2869451920 分钟前
Case-Based Reasoning用于RAG
人工智能·算法·chatgpt
Athenaand21 分钟前
代码随想录算法训练营第50天 | 图论理论基础、深搜理论基础、98. 所有可达路径、广搜理论基础
算法·图论
地平线开发者26 分钟前
征程 6 灰度图部署链路介绍
人工智能·算法·自动驾驶·汽车
好多171 小时前
《微服务事务管理》
java·微服务·架构