当前位置: 首页 > article >正文

「力扣面试经典150题」189. 轮转数组

「力扣面试经典150题」189. 轮转数组

题目描述

给定长度为 n n n的数组 a r ar ar,将数组中的元素向右轮转 k k k个位置,其中 k k k是非负数

要求使用空间复杂度为 O ( 1 ) O(1) O(1)的原地算法解决

思路1:

比较粗糙一点的想法是,选定某个位置,从当前位置开始往后找到右边第k个位置,进行赋值,继续找下一个,知道回到最初选定的位置

但是很显然,有的时候不会只走一圈就全部轮转成功,我们需要考虑一下最少需要选几个数字可以覆盖整个数组。

假设从0出发,回到0的时候一共走了 a a a圈,经历了 b b b个数字,则可以得到恒等式 a ∗ n = k ∗ b a*n=k*b an=kb,同时,不难发现,从任意一个点出发,走n和k的最小公倍数的倍数圈就可以回到原点,所以最小值就取 l c m ( n , k ) lcm(n,k) lcm(n,k),即 a ∗ n = l c m ( n , k ) a*n=lcm(n,k) an=lcm(n,k),根据恒等式, k ∗ b = a ∗ n = l c m ( n , k ) k*b = a*n=lcm(n, k) kb=an=lcm(n,k),可以得到 b = l c m ( n , k ) k b=\frac{lcm(n,k)}{k} b=klcm(n,k),每走一圈可以遍历到b个数字,想遍历 n n n个数字,则只需要取前num个, n u m = n b = n l c m ( n , k ) k = n ∗ k l c m ( n , k ) num = \frac{n}{b} = \frac{n}{\frac{lcm(n, k)}{k}} = \frac{n * k}{lcm(n, k)} num=bn=klcm(n,k)n=lcm(n,k)nk,由于 n ∗ k = g c d ( n , k ) ∗ l c m ( n , k ) n*k=gcd(n,k)*lcm(n, k) nk=gcd(n,k)lcm(n,k),所以 n u m = g c d ( n , k ) num = gcd(n, k) num=gcd(n,k)

class Solution {
public:
    int gcd(int x, int y){
        if(y == 0)return x;
        return gcd(y, x % y);
    }
    void rotate(vector<int>& num, int k) {
        int n = num.size();
        k %= n;
        if(k == 0)return;
        for(int p = 0; p < gcd(n, k); ++p){
            int u = p, x = num[u], y = 0;
            do{
                int v = (u + k) % n;
                y = num[v];
                num[v] = x;
                x = y;
                u = v;
            }while(u != p);
        }
    
    }
};

思路2:

三次翻转数组

首先把整个数组反转一遍,再将前 k k k个数反转一遍,再将后 n − k n-k nk个数反转一遍即可得到答案

class Solution {
public:
    void rotate(vector<int>& nums, int k) {
        int n = nums.size();
        k %= n;
        if(k == 0)return;
        reverse(nums.begin(), nums.end());
        for(int l = 0, r = k - 1; l < r; ++l, --r){
            swap(nums[l], nums[r]);
        }
        for(int l = k, r = n - 1; l < r; ++l, --r){
            swap(nums[l], nums[r]);
        }
    }
};

http://www.kler.cn/a/559684.html

相关文章:

  • ClickHouse系列之ClickHouse安装
  • CentOS7 离线安装 Postgresql 指南
  • 自建Dify如何白嫖Gemini?
  • 讯飞离线唤醒+离线Vosk识别+DeepSeek大模型+讯飞离线合成持续优化,无限可能~
  • Java 使用注解实现Redisson分布式锁
  • 【异常错误】pycharm debug view变量的时候显示不全,中间会以...显示
  • ubuntu 磁盘恢复
  • 基于 Python Django 的校园互助平台(附源码,文档)
  • 云端SaaS系统架构设计
  • 在Ubuntu下通过Docker部署WordPress服务器
  • Java 与设计模式(16):命令模式
  • SessionBox同一浏览器登录多账号独立IP教程
  • 从【人工智能】到【计算机视觉】,【深度学习】引领的未来科技创新与变革
  • flutter在安卓模拟器上运行
  • 复现论文:DPStyler: Dynamic PromptStyler for Source-Free Domain Generalization
  • 详解 @符号在 PyTorch 中的矩阵乘法规则
  • 二:前端发送POST请求,后端获取数据
  • 基于python实现机器学习的心脏病预测系统
  • 23贪心算法
  • 在 Mac mini M2 上使用Docker快速部署MaxKB:打造本地知识库问答系统