题目地址 : 旋转数组.

网上好多不是根本就是错的,就是空间复杂度不是真正为1

下面总结一下

方法1

普通方法(空间复杂度不满足要求,但是题目并不会判错,说明他们没用对空间进行校验)

···

public void rotate1(int[] nums, int k) {

if(nums.length == 1 || k == 0) return;

    k = k % nums.length;
int[] ans = new int[nums.length];
for (int i = 0, j = k; i < nums.length; i++) {
ans[j] = nums[i];
j = (j+1) % nums.length;
}
System.out.println("Arrays.toString(ans) = " + Arrays.toString(ans));
for(int i = 0; i < nums.length; i++){
nums[i] = ans[i];
}
}

···

方法2:

3次倒置,这个方法思路很巧妙,很经典。

先全部倒置,然后0到k-1倒置,然后k到最后再倒置,就得到了正确结果,空间复杂度1,(交换只耗费1个额外空间)

倒置当然要自己写,用java自带的肯定就超过1空间复杂度了

方法3

这是我自己想的方法,每次把当前的给正确的位置,然后在把正确位置上的那个再给下一个正确的位置,但是这个方法有个坑,就是不一定一次轮回就能搞定,如果k和length都是偶数就会超过一次轮回。

我也没研究出来到底是几次轮回,但是有一种简单的方法,就是每次调换一次,就cnt++,当cnt==length的时候就完成了。在这之前不断轮回,每次轮回,从当前的位置+1. 第一次轮回把nums[0]当成一个临时变量(每次轮回完了,num[0]自动会是正确的数字, 第二次轮回就是num[1]...)

public void rotate(int[] nums, int k) {
if(nums.length == 1 || k == 0) return;
k = k % nums.length;
int cnt = 0, r = 0, j;
while(cnt < nums.length){
j = k + r;
while (true) {
System.out.println(nums[r] + " " + nums[j]);
int t = nums[j];
nums[j] = nums[r];
nums[r] = t;
j = (j + k) % nums.length;
cnt++;
if(j == r){
cnt++;
break;
}
}
System.out.println(Arrays.toString(nums));
r++;
}
// System.out.println( Arrays.toString(nums));
}

旋转数组 空间复杂度为O(1) 的2 种方法 + 1种空间复杂度O(n)的更多相关文章

  1. leetCode 81.Search in Rotated Sorted Array II (旋转数组的搜索II) 解题思路和方法

    Follow up for "Search in Rotated Sorted Array": What if duplicates are allowed? Would this ...

  2. 《剑指offer》面试题8 旋转数组的最小数字 Java版

    (找递增排序旋转数组中的最小数字) 书中方法:这种题目就是要寻找数组的特点,然后根据这个特点去写.旋转后的递增数组分为两段递增序列,我们找到中点,如果比第一个元素大,表示在第一段递增序列里,如果比第一 ...

  3. C# byte[]数组和string的互相转化 (四种方法)

    C# byte[]数组和string的互相转化 (四种方法) 第一种 [csharp] view plain copy string str = System.Text.Encoding.UTF8.G ...

  4. js数组和字符串去重复几种方法

    js数组去重复几种方法 第一种:也是最笨的吧. Array.prototype.unique1 = function () { var r = new Array(); label:for(var i ...

  5. [LeetCode] Rotate Array 旋转数组

    Rotate an array of n elements to the right by k steps. For example, with n = 7 and k = 3, the array  ...

  6. 【LeetCode每天一题】Search in Rotated Sorted Array(在旋转数组中搜索)

    Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.(i.e., ...

  7. leecode刷题(3)-- 旋转数组

    leecode刷题(3)-- 旋转数组 旋转数组 给定一个数组,将数组中的元素向右移动 K 个位置,其中 K 是非负数. 示例: 输入: [1,2,3,4,5,6,7] 和 k = 3 输出: [5, ...

  8. 旋转数组 [ LeetCode ]

    原题地址:https://leetcode-cn.com/problems/rotate-array/description/ 给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数. ...

  9. 剑指Offer - 九度1386 - 旋转数组的最小数字

    剑指Offer - 九度1386 - 旋转数组的最小数字2013-11-24 01:57 题目描述: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转 ...

随机推荐

  1. BZOJ 3118 Orz the MST

    权限题qwq 如果我们要使得某棵生成树为最小生成树,那么上面的边都不能被替代,具体的,对于一个非树边,它的权值要\(\ge\)它两端点在树上的路径上的所以边的权值,所以对于每个非树边就可以对一些树边列 ...

  2. java.lang.IllegalArgumentException: id to load is required for loading

    java.lang.IllegalArgumentException: id to load is required for loading at org.hibernate.event.LoadEv ...

  3. 七、for循环

    for循环

  4. 77. Combinations (JAVA)

    Given two integers n and k, return all possible combinations of k numbers out of 1 ... n. For exampl ...

  5. pycharm 的一个小问题

    版本:PyCharm 2018.3.7 (Professional Edition) 这段时间用pycharm写python代码,运行网上copy的代码.报错了也就是少个模块或者Python2的语法在 ...

  6. [POJ1664]放苹果(动态规划)

    [POJ1664]放苹果 Description 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法. Input 第 ...

  7. 阅读之SQL优化

    一.性能不理想的系统中除了一部分是因为应用程序的负载确实超过了服务器的实际处理能力外,更多的是因为系统存在大量的SQL语句需要优化. 为了获得稳定的执行性能,SQL语句越简单越好.对复杂的SQL语句, ...

  8. MYSQL<四>

    -- ########## 01.ER关系 ########## -- ER关系(逻辑描述) -- A:E---Entity简写,实体,具有相同属性(特征)的对象归为同一实体 -- Attribute ...

  9. python-pillow图像处理

    安装 pip3 install pillow PIL中所涉及的基本概念有如下几个:通道(bands).模式(mode).尺寸(size).坐标系统(coordinate system).调色板(pal ...

  10. Docker(六):Dockerfile命令详解

    Dockerfile 指令详解 1 FROM 指定基础镜像 FROM 指令用于指定其后构建新镜像所使用的基础镜像.FROM 指令必是 Dockerfile 文件中的首条命令,启动构建流程后,Docke ...