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);
}
相关推荐
.Ashy.7 小时前
2026.4.11 蓝桥杯软件类C/C++ G组山东省赛 小记
c语言·c++·蓝桥杯
2401_892070988 小时前
链栈(链式栈) 超详细实现(C 语言 + 逐行精讲)
c语言·数据结构·链栈
语戚9 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_119 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
田梓燊11 小时前
leetcode 160
算法·leetcode·职场和发展
_深海凉_11 小时前
LeetCode热题100-颜色分类
python·算法·leetcode
cmpxr_11 小时前
【C】局部变量和全局变量及同名情况
c语言·开发语言
6Hzlia12 小时前
【Hot 100 刷题计划】 LeetCode 136. 只出现一次的数字 | C++ 哈希表&异或基础解法
c++·算法·leetcode
无限进步_13 小时前
【C++】只出现一次的数字 II:位运算的三种解法深度解析
数据结构·c++·ide·windows·git·算法·leetcode
网域小星球13 小时前
C 语言从 0 入门(十七)|结构体指针 + 动态内存 + 文件综合实战
c语言·开发语言·文件操作·结构体指针·动态内存·综合项目