旋转数组 空间复杂度为O(1) 的2 种方法 + 1种空间复杂度O(n)
题目地址 : 旋转数组.
网上好多不是根本就是错的,就是空间复杂度不是真正为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)的更多相关文章
- leetCode 81.Search in Rotated Sorted Array II (旋转数组的搜索II) 解题思路和方法
Follow up for "Search in Rotated Sorted Array": What if duplicates are allowed? Would this ...
- 《剑指offer》面试题8 旋转数组的最小数字 Java版
(找递增排序旋转数组中的最小数字) 书中方法:这种题目就是要寻找数组的特点,然后根据这个特点去写.旋转后的递增数组分为两段递增序列,我们找到中点,如果比第一个元素大,表示在第一段递增序列里,如果比第一 ...
- C# byte[]数组和string的互相转化 (四种方法)
C# byte[]数组和string的互相转化 (四种方法) 第一种 [csharp] view plain copy string str = System.Text.Encoding.UTF8.G ...
- js数组和字符串去重复几种方法
js数组去重复几种方法 第一种:也是最笨的吧. Array.prototype.unique1 = function () { var r = new Array(); label:for(var i ...
- [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 ...
- 【LeetCode每天一题】Search in Rotated Sorted Array(在旋转数组中搜索)
Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.(i.e., ...
- leecode刷题(3)-- 旋转数组
leecode刷题(3)-- 旋转数组 旋转数组 给定一个数组,将数组中的元素向右移动 K 个位置,其中 K 是非负数. 示例: 输入: [1,2,3,4,5,6,7] 和 k = 3 输出: [5, ...
- 旋转数组 [ LeetCode ]
原题地址:https://leetcode-cn.com/problems/rotate-array/description/ 给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数. ...
- 剑指Offer - 九度1386 - 旋转数组的最小数字
剑指Offer - 九度1386 - 旋转数组的最小数字2013-11-24 01:57 题目描述: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转 ...
随机推荐
- AIX系统的备份和恢复
1.AIX备份命令
- 第一节,搭建openwrt开发环境
一,安装VMware虚拟机或者VirtualBox虚拟机 安装过程就不在此赘述了.附上百度搜索来的链接,供大家参考. https://baijiahao.baidu.com/s?id=16233731 ...
- ELF程序头部及程序加载
程序头部 程序头部描述与程序执行直接相关的目标文件结构信息.用来在文件中定位各个段的映像.同时包含其他一些用来为程序创建进程映像所必需的信息. 可执行文件或者共享目标文件的程序头部是一个结构数组,每个 ...
- AI应该享有与动物一样的权利吗?
全世界的大学都在进行人工智能(AI)的重大研究,艾伦研究所(Allen Institute)等组织以及Google和Facebook等高科技公司.可能的结果是,我们很快将拥有与小鼠或狗一样高的认知能力 ...
- JAVA笔记25-IO流(3)-处理流举例
处理流类型: 1.缓冲流 例1: import java.io.*; public class TestBufferStream{ public static void main(String arg ...
- spark性能调优点(逐步完善)
1.使用高性能序列化类库2.优化数据结构3.对多次使用的RDD进行持久化/CheckPoint4.使用序列化的持久化级别5.Java虚拟机垃圾回收调优 降低RDD缓存占用空间的比例:new Spark ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 L. Digit sum
题目:https://nanti.jisuanke.com/t/41422 思路:预处理 #include<bits/stdc++.h> using namespace std; ][]= ...
- shiro框架学习-1-shiro基本概念
1. 什么是权限控制 基本上涉及到用户参与的系统都要进行权限管理,权限管理属于系统安全的范畴,权限管理实现对用户访问系统的控制,按照安全规则或者安全策略控制用户可以访问而且只能访问自己被授权的资源, ...
- node 的CommonJS的引入
1.CommonJS 每个文件是一个模块,有自己的作用域 引入:
- mysql AUTO INCREMENT字段 语法
mysql AUTO INCREMENT字段 语法 作用:在新记录插入表中时生成一个唯一的数字 说明:我们通常希望在每次插入新记录时,自动地创建主键字段的值.我们可以在表中创建一个 auto-incr ...