js求解《初级算法》141. 环形链表
创始人
2024-05-30 00:37:14

一、题目描述

        

        给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false 。

 

输入:head = [3,2,0,-4], pos = 1

输出:true

解释:链表中有一个环,其尾部连接到第二个节点。

二、思路

这道题有两种解法:哈希表判断重复、快慢指针算相遇

  1. 哈希表  核心思想:如果存在环,则哈希表必将重复,我们只需要将链表逐个添加到哈希表,判断是否重复,有就返回true

  2. 快慢指针 核心思想,如果存在环,则快慢指针终会相遇,我们只需要判断快指针是否与慢指针相遇,有就返回true

三、代码展示

  1. 哈希表
    var hasCycle = function(head) {let set = new Set()while(head) {if(set.has(head)) {return true}set.add(head)head = head.next}return false
    };
  2. 快慢指针
    var hasCycle = function (head) {let slow = head;let fast = head;//如果没有环,则快指针会抵达终点,否则继续移动双指针while (fast && fast.next) {slow = slow.next;fast = fast.next.next;//快慢指针相遇,说明含有环if (slow == fast) {return true;}}return false;
    };

相关内容

热门资讯

撕开0蔗糖营销假象:代糖套路暗... 来源:金综科技当下健康消费热潮中,各类饮品、酸奶主打“0蔗糖”卖点,深受减脂、控糖人群青睐。但多数商...
中央第七生态环境保护督察组交办... 本报乌鲁木齐讯(全媒体记者 张贝) 2026年6月10日,中央第七生态环境保护督察组向兵团交办第...
自治区推动爱国卫生工作由环境卫... 本报乌鲁木齐讯(全媒体记者 郑娅莉) 今年5月1日,新修订的《新疆维吾尔自治区爱国卫生工作条例》...
知名车企停产三款国产电车!知情... (来源:车联新生态)据多家媒体报道,宝马将于今年7月起全面停产i3、i5、iX1三款国产纯电车型。针...
哪款好智能手表排行榜 中老年家... 清晨量血压前顺手抬腕查看昨夜深睡时长,服药提醒在表盘轻震浮现,散步途中血氧饱和度实时波动曲线悄然生成...