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);
}
相关推荐
666HZ6668 小时前
C语言——高精度加法
c语言·开发语言·算法
666HZ6668 小时前
C语言——黑店
c语言·开发语言
云里雾里!9 小时前
力扣 209. 长度最小的子数组:滑动窗口解法完整解析
数据结构·算法·leetcode
CoderYanger10 小时前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:12.全排列
java·算法·leetcode·机器学习·深度优先·剪枝·1024程序员节
chem411111 小时前
C 语言 函数指针和函数指针数组
c语言·数据结构·算法
liu****11 小时前
八.函数递归
c语言·开发语言·数据结构·c++·算法
芯联智造12 小时前
【stm32简单外设篇】- 单路 TTP223 电容式触摸传感器
c语言·stm32·单片机·嵌入式硬件
枫叶丹412 小时前
【Qt开发】Qt窗口(三) -> QStatusBar状态栏
c语言·开发语言·数据库·c++·qt·microsoft
小猪写代码13 小时前
C语言系统函数-(新增)
c语言·开发语言
♛识尔如昼♛13 小时前
C 基础(3-2) - 数据和C
c语言·开发语言