leetcode第189题:轮转数组(C语言版)

思路1(不推荐)
保存数组最后一个元素,然后数组全体元素后移一位,把保存的最后一个元素存放到数组的第一个位置,重复这一操作,直到执行完了k次。
时间复杂度:需要用k次循环,里面套一层N-1次循环,最后循环k*(N-1)次;最坏结果中,k值为N-1,此时时间复杂度为O(N^2)。(大O渐进表示法只考虑最坏的情况)
空间复杂度:未使用新开辟的空间,空间复杂度为O(1)。


思路2(最优解)

前n-k个元素逆置,然后后k个逆置,最后再整体逆置。如下图所示。

时间复杂度:三次循环,结果为O(N)。

空间复杂度:未使用新开辟的空间,空间复杂度为O(1)。


思路3

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

时间复杂度:O(N)

空间复杂度:O(N)


思路4

开辟一个额外的数组,把k个元素存入;然后在原数组中,从n-k开始,与元素进行交换。交换以后把k个元素再放入原数组即可。

时间复杂度:O(N)

空间复杂度:O(N)

思路2

思路3

思路2代码:

cpp 复制代码
void reverse(int a[],int left,int right)
{
    while(left<right)
    {
        int tmp=a[left];
        a[left]=a[right];
        a[right]=tmp;
        left++;
        right--;
    }
}

void rotate(int* nums, int numsSize, int k) {
    k%=numsSize;
    if(numsSize==1)
    {
        return;
    }
    reverse(nums,0,numsSize-k-1);
    reverse(nums,numsSize-k,numsSize-1);
    reverse(nums,0,numsSize-1);
}
相关推荐
com_4sapi4 分钟前
2025 权威认证头部矩阵系统全景对比发布 双榜单交叉验证
大数据·c语言·人工智能·算法·矩阵·机器人
Miraitowa_cheems31 分钟前
LeetCode算法日记 - Day 102: 不相交的线
数据结构·算法·leetcode·深度优先·动态规划
Miraitowa_cheems34 分钟前
LeetCode算法日记 - Day 101: 最长公共子序列
数据结构·算法·leetcode·深度优先·动态规划
芯联智造1 小时前
【stm32协议外设篇】- PAJ7620手势识别传感器
c语言·stm32·单片机·嵌入式硬件
玖剹2 小时前
二叉树递归题目(一)
c语言·c++·算法·leetcode
沧澜sincerely2 小时前
BFS & 图论【各种题型+对应LeetCode习题练习】
leetcode·图论·广度优先
量子炒饭大师2 小时前
【一天一个计算机知识】—— 【编程百度】翻译环境与运行环境
c语言·汇编·c++·gitee·机器翻译
不穿格子的程序员2 小时前
从零开始写算法——二分-寻找旋转排序数组中的最小值
数据结构·算法·leetcode·二分查找
小白程序员成长日记2 小时前
2025.11.13 力扣每日一题
算法·leetcode·职场和发展
_fairyland6 小时前
数据结构 力扣 练习
数据结构·考研·算法·leetcode