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);
}
相关推荐
smj2302_7968265210 小时前
解决leetcode第3768题.固定长度子数组中的最小逆序对数目
python·算法·leetcode
cynicme10 小时前
力扣3531——统计被覆盖的建筑
算法·leetcode
程序员Jared12 小时前
深入浅出C语言——程序环境和预处理
c语言
圣保罗的大教堂12 小时前
leetcode 3531. 统计被覆盖的建筑 中等
leetcode
应茶茶12 小时前
从 C 到 C++:详解不定参数的两种实现方式(va_args 与参数包)
c语言·开发语言·c++
福尔摩斯张13 小时前
Linux信号捕捉特性详解:从基础到高级实践(超详细)
linux·运维·服务器·c语言·前端·驱动开发·microsoft
【蜡笔小新】14 小时前
《筑基篇》C语言基础2
c语言·开发语言
学习路上_write14 小时前
AD5293驱动学习
c语言·单片机·嵌入式硬件·学习
Herbert_hwt15 小时前
C语言一维数组完全指南:从基础到实战应用
c语言