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--;
        }
    }
相关推荐
Jay Kay2 小时前
GVPO:Group Variance Policy Optimization
人工智能·算法·机器学习
Mr_sun.2 小时前
Day09——入退管理-入住-2
android·java·开发语言
Epiphany.5562 小时前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
MAGICIAN...2 小时前
【java-软件设计原则】
java·开发语言
JH30732 小时前
为什么switch不支持long
java
YuTaoShao2 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
盐真卿2 小时前
python第八部分:高级特性(二)
java·开发语言
茉莉玫瑰花茶2 小时前
C++ 17 详细特性解析(5)
开发语言·c++·算法
上海合宙LuatOS3 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
汤姆yu3 小时前
基于springboot的尿毒症健康管理系统
java·spring boot·后端