数据结构:旋转数组

方法1 (三次逆置法):

cpp 复制代码
void reverse(int* nums, int start, int end) {
    while (start < end) {
        int temp = nums[start];
        nums[start] = nums[end];
        nums[end] = temp;
        start++;
        end--;
    }
}

void rotate(int* nums, int numsSize, int k) {
    k = k % numsSize;  // 防止 k 大于数组长度
    if (k == 0) return;  // 如果 k 为 0,则无需旋转

    reverse(nums, 0, numsSize - 1);      // 逆置整个数组
    reverse(nums, 0, k - 1);             // 逆置前 k 个元素
    reverse(nums, k, numsSize - 1);      // 逆置剩余的元素
}

时间复杂度:O(N),空间复杂度:O(1)

方法2(使用临时数组):

cpp 复制代码
void rotate(int* nums, int numsSize, int k) {
    k = k % numsSize;  // 防止 k 大于数组长度
    if (k == 0) return;  // 如果 k 为 0,则无需旋转

    // 分配内存保存最后 k 个元素
    int* temp = (int*)malloc(sizeof(int) * k);
    if (temp == NULL) {
        printf("动态开辟失败\n");
        return;
    }

    // 保存最后 k 个元素到临时数组中
    for (int i = 0; i < k; i++) {
        temp[i] = nums[numsSize - k + i];
    }

    // 将前面的元素向后移动
    for (int i = numsSize - k - 1; i >= 0; i--) {
        nums[i + k] = nums[i];
    }

    // 将临时数组中的元素移到前面
    for (int i = 0; i < k; i++) {
        nums[i] = temp[i];
    }

    // 释放临时数组
    free(temp);
}

时间复杂度:O(N) ,空间复杂度:O(N)

相关推荐
2301_816997881 分钟前
虚拟DOM与Diff算法
前端·vue.js·算法
闻缺陷则喜何志丹1 分钟前
P8153 「PMOI-5」送分题/Yet Another Easy Strings Merging|普及+
c++·数学·算法·洛谷
tankeven4 分钟前
HJ102 字符统计
c++·算法
升讯威在线客服系统10 分钟前
从 GC 抖动到稳定低延迟:在升讯威客服系统中实践 Span 与 Memory 的高性能优化
java·javascript·python·算法·性能优化·php·swift
We་ct18 分钟前
LeetCode 199. 二叉树的右视图:层序遍历解题详解
前端·算法·leetcode·typescript·广度优先
孤独的追光者18 分钟前
MATLAB导出滤波器参数至ADSP中使用
算法·matlab
鲨辣椒1008626 分钟前
线程函数接口补充
java·开发语言·算法
0 0 034 分钟前
CCF-CSP 33-2 相似度计算(jaccard)【C++】考点:STL容器(set/map)
开发语言·c++·算法
每天要多喝水37 分钟前
图论Day38:孤岛基础
算法·深度优先·图论
瓦特what?1 小时前
波 浪 排 序
c++·算法·排序算法