热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

LeetCode:189.轮转数组(Java)

方法1:跳序轮转法——带标记,时间复杂度和空间复杂度均为O(n)因为有些特殊情况,会陷入循环,比如这个例子:


方法1: 跳序 轮转法——带标记,时间复杂度和空间复杂度均为O(n)

因为有些特殊情况,会陷入循环,比如这个例子:

我不知道怎么处理这种情况,所以直接搞个标记数组falgs[]来看看这个位置的数字是否被处理过。方法二来改进这个陷入循环的问题

class Solution {public void rotate(int[] nums, int k) {// 1.跳序 轮转法——带标记,时间复杂度和空间复杂度均为O(n)int len=nums.length;int[] flags=new int[len];Arrays.fill(flags,0);int next;int curr=0;int tmp=nums[curr]; //临时保存上一个int tmp1; //临时保存当前的int n=len;while(n!=0 && k!=0){// if(n!=len && len%k==0 &&n%(len/k)==0){// curr++;// tmp=nums[curr];// }next=(curr+k)%len;while(flags[next]==1){next=(next+1)%len;if(flags[next]==1)continue;else {curr=next;tmp = nums[curr];next = (curr + k) % len;}}tmp1=nums[next];nums[next]=tmp;tmp=tmp1;curr=next;flags[curr]=1;n--;}}
}


方法2:类1-跳序轮转法——不借助flag数组 

这里稍微对pos==i解释一下,因为pos如果一次陷入循环,意味着pos会在不同的轮转中循环,即跳出一个轮回会进入下一个轮换,在每个轮回中都会陷入循环。pos是从0开始,那当pos跳转一轮回到起点0以后,就派i(可以看做pos的初始)对线,发现跟初始0一样,就开始对pos+1处理。

(我们把这样叫一次轮转,从pos=0出发,回到pos=0)

class Solution {public void rotate(int[] nums, int k) {// 5.类1-跳转轮转法:他人解法,不借助flag数组int len = nums.length,n = len;int i = 0,pos = 0, pre = nums[pos],temp = nums[pos];if(k%n == 0) return;while (n-- != 0) {pos = (pos + k) % len;temp = nums[pos];nums[pos] = pre;pre = temp;if (pos == i) { // 避免陷入循环pos = ++i;pre = nums[pos];temp = nums[pos];}}}
}


方法3:借助另外一个数组保存每次移动的数——以空间换时间

class Solution {public void rotate(int[] nums, int k) {// 双数组:顺序 轮转法——借助另一个数组。int len=nums.length;int[] res=Arrays.copyOf(nums,len);int next;for(int i=0;i}


方法4:翻转数组——有点巧妙的

class Solution {public void rotate(int[] nums, int k) { // 4.三次翻转数组&#xff0c;找出k%n的那个位置点——耗时最少int len&#61;nums.length;int pos&#61;k%(len);reverse(nums,0,len);reverse(nums,0,pos);reverse(nums,pos,len);}public void reverse(int[] nums,int start,int end){int tmp;int i&#61;0;while(i<(end-start)/2){tmp&#61;nums[end-1-i];nums[end-1-i]&#61;nums[start&#43;i];nums[start&#43;i]&#61;tmp;i&#43;&#43;;}}
}


方法5&#xff1a;每次向前移动一位&#xff0c;重复k次&#xff08;超出时间限制&#xff09;

class Solution {public void rotate(int[] nums, int k) {// 3.单次轮转k次法O(n*k)——超出时间限制×int len&#61;nums.length;int tmp;while((k--)!&#61;0){tmp&#61;nums[0];for(int i&#61;1;i}


推荐阅读
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
author-avatar
278787061w
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有