博客
关于我
环形数组循环
阅读量:405 次
发布时间:2019-03-06

本文共 1909 字,大约阅读时间需要 6 分钟。

环形数组循环

给定一个含有正整数和负整数的环形数组nums,如果某个索引中的数k为正数,则向前移动 k个索引,相反如果是负数-k,则向后移动k个索引。因为数组是环形的,所以可以假设最后一个元素的下一个元素是第一个元素,而第一个元素的前一个元素是最后一个元素,确定nums中是否存在循环或周期。循环必须在相同的索引处开始和结束并且循环长度>1。此外,一个循环中的所有运动都必须沿着同一方向进行,换句话说,一个循环中不能同时包括向前的运动和向后的运动。

示例

输入:[2,-1,1,2,2]输出:true解释:存在循环,按索引 0 -> 2 -> 3 -> 0 。循环长度为 3 。
输入:[-1,2]输出:false解释:按索引 1 -> 1 -> 1 ... 的运动无法构成循环,因为循环的长度为 1 。根据定义,循环的长度必须大于 1 。
输入:[-2,1,-1,-2,-2]输出:false解释:按索引 1 -> 2 -> 1 -> ... 的运动无法构成循环,因为按索引 1 -> 2 的运动是向前的运动,而按索引 2 -> 1 的运动是向后的运动。一个循环中的所有运动都必须沿着同一方向进行。

题解

/** * @param {number[]} nums * @return {boolean} */var circularArrayLoop = function(nums) {    var n = nums.length;    var getNext = x => {        var nextIndex = (x+nums[x])%n;        return nextIndex >= 0 ? nextIndex : nextIndex+n;    };    for(let i=0;i
0 && nums[fast] * nums[getNext(fast)] > 0){ if(slow === fast){ if(slow === getNext(slow)) break; else return true; } slow = getNext(slow); fast = getNext(getNext(fast)); } let tmp = i; let val = nums[tmp]; while(val * nums[tmp] > 0){ let k = getNext(tmp); nums[tmp] = 0; tmp = k; } } return false;};

思路

首先需要解释一下题意,以示例1[2,-1,1,2,2]为例,最开始是索引0值为2,那么索引向前走2步到索引2值为1,继续向前走1步到达索引3值为2,再向前走2步循环索引回到0,所以这完成了一次循环,这里的起始点并不一定是索引0,起始点可以为任意索引位置,其次就是限制条件循环的长度必须大于1以及一个循环中的所有运动都必须沿着同一方向进行。

本题使用快慢指针来做,快指针每次走两步,慢指针每次走一步,如果能够达成循环那么快慢指针必定会相遇,当然在此处一步与两步指的是移动一个nums[i]的步长,不是移动index+1,首先定义一个n为数组长度以及getNext方法作为取得该点的下一步的索引值,之后遍历数组,根据定义,数组中不能存在0元素,所以以0为标记值进行剪枝,以慢指针指向i,快指针指向下一步的索引,while循环中第一个判断是保证慢指针与快指针指向的数组值符号相同,第二个判断是保证快指针指向的数组值与下一个快指针指向的数组值同号,保证一个循环中的所有运动都必须沿着同一方向进行,之后如果快慢指针相遇,则判断是否循环的长度为1,若循环的长度为1则不符合条件,便继续查找,否则就可以说明该数组中存在循环,之后便是slow指针走一步,fast指针走两部,最后需要剪枝,因为已经遍历过的元素不可能出现在循环当中,所以将以i为索引开始的每一步都置0,用以实现剪枝。

每日一题

https://github.com/WindrunnerMax/EveryDay

参考

https://leetcode-cn.com/problems/circular-array-loop

转载地址:http://apckz.baihongyu.com/

你可能感兴趣的文章
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
查看>>