热门标签 | 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泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 本文详细介绍如何在VSCode中配置自定义代码片段,使其具备与IDEA相似的代码生成快捷键功能。通过具体的Java和HTML代码片段示例,展示配置步骤及效果。 ... [详细]
  • 本文探讨了在Java多线程环境下,如何确保具有相同key值的线程能够互斥执行并按顺序输出结果。通过优化代码结构和使用线程安全的数据结构,我们解决了线程同步问题,并实现了预期的并发行为。 ... [详细]
  • 本文详细介绍了Java中的输入输出(IO)流,包括其基本概念、分类及应用。IO流是用于在程序和外部资源之间传输数据的一套API。根据数据流动的方向,可以分为输入流(从外部流向程序)和输出流(从程序流向外部)。此外,还涵盖了字节流和字符流的区别及其具体实现。 ... [详细]
  • 汇编语言等号伪指令解析:探究其陡峭的学习曲线
    汇编语言以其独特的特性和复杂的语法结构,一直被认为是编程领域中学习难度较高的语言之一。本文将探讨汇编语言中的等号伪指令及其对初学者带来的挑战,并结合社区反馈分析其学习曲线。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 本文详细介绍了如何解决MyBatis中常见的BindingException错误,提供了多种排查和修复方法,确保Mapper接口与XML文件的正确配置。 ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 本文介绍了如何通过配置 Android Studio 和 Gradle 来显著提高构建性能,涵盖内存分配优化、并行构建和性能分析等实用技巧。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 本文探讨了在Java中实现系统托盘最小化的两种方法:使用SWT库和JDK6自带的功能。通过这两种方式,开发者可以创建跨平台的应用程序,使窗口能够最小化到系统托盘,并提供丰富的交互功能。 ... [详细]
  • 本文总结了Java程序设计第一周的学习内容,涵盖语言基础、编译解释过程及基本数据类型等核心知识点。 ... [详细]
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社区 版权所有