leetcode189:轮转数组

leetcode189轮转数组

给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。

最大公约数法:

时间复杂度O(n^2)

空间复杂度O(1)

解析:

k和数组长度的最大公约数为n

代表数据可以分为n组去移动

做n次循环向后移动k位即可

java 复制代码
public void rotate(int[] nums, int k) {
        if(k>=nums.length){
            k = k%nums.length;
        }
        if(k == 0) {
            return;
        }
        int tmpa = k;
        int tmpb = nums.length;
        int tmpc = 0;
        while(tmpb != 0){
            tmpc = tmpa%tmpb;
            tmpa = tmpb;
            tmpb = tmpc;
        }

        for (int j = 0; j< tmpa; j++) {
                //下一次要存的位置
                int res = k+j;
                int start = nums[j];
                for (int i = 0; i < nums.length/tmpa; i++) {
                    int end = nums[res%nums.length];
                    nums[res] = start;
                    res = (res + k) % nums.length;
                    start = end;
                }
        }
    }
三次反转法

解析:

1234567->5671234

即->7654321-> 765 4321 ->567 1234

三次反转完成

java 复制代码
 public void rotate(int[] nums, int k) {
        if(k>=nums.length){
            k = k%nums.length;
        }
        if(k == 0) {
            return;
        }
        this.reverse(nums,0,nums.length-1);
        this.reverse(nums,0,k-1);
        this.reverse(nums,k,nums.length-1);
    }

    public void reverse(int[] nums,int start,int end){
        int tmp = 0;
        while(start < end){
            tmp = nums[start];
            nums[start] = nums[end];
            nums[end] = tmp;
            start++;
            end--;
        }
    }
相关推荐
sheji341619 小时前
【开题答辩全过程】以 某高校教学仪器设备管理系统设计与开发为例,包含答辩的问题和答案
java
小宇的天下19 小时前
Calibre nmDRC-H 层级化 DRC
java·服务器·前端
毕设源码-钟学长19 小时前
【开题答辩全过程】以 面向社区的网上书店为例,包含答辩的问题和答案
java
sunddy_x19 小时前
Spring事务
java·spring·mybatis
夏鹏今天学习了吗19 小时前
【LeetCode热题100(84/100)】乘积最大子数组
算法·leetcode·职场和发展
量子炒饭大师19 小时前
【C++入门】骇客数据面向对象的灵魂锚点——【类与对象】this指针篇
java·c++·dubbo·this·this指针
J_liaty19 小时前
Spring Boot整合Shiro实现权限认证
java·spring boot·后端·shiro
花间相见19 小时前
【JAVA开发】—— Git常用操作
java·开发语言·git
Yupureki19 小时前
《算法竞赛从入门到国奖》算法基础:入门篇-递归初阶
c语言·开发语言·数据结构·c++·算法·visual studio
a35354138219 小时前
牛顿迭代法中的雅克比矩阵几何意义
线性代数·算法