【leetcode】环形链表及拓展

                                              环形链表及拓展

一、要求

给定一个链表,判断链表中是否有环。

进阶:
你能否不使用额外空间解决此题?

节点类:

 class ListNode {
        public int val;
        public ListNode next;

        ListNode(int val) {
            this.val = val;
            this.next = null;
        }
    }

二、解法

(1)使用额外空间来判断链表中是否有环

思路:遍历整个链表,将每一次遍历的节点存入Set中,利用Set存入相同元素返回false的特性,判断链表中是否有环。

 public boolean hasCycle(ListNode head) {
        Set<ListNode> set = new HashSet<>();
        while (head != null) {
            boolean result = set.add(head);
            if (!result) {
                return true;
            }
            head = head.next;
        }
        return false;
    }

由于遍历,导致时间复杂度为O(n),由于使用了Set集合,空间复杂度为O(n)。


(2)使用快慢指针。

思路:快慢指针都从头节点开始,快指针一次走两步,慢指针一次,如果慢指针能够追赶上快指针,则证明链表中有环。

 public boolean hasCylce2(ListNode head) {
        ListNode slow = head;
        ListNode fast = head;
        while (fast != null && fast.next != null) {
            fast = fast.next.next;
            slow = slow.next;
            //如果慢指针追赶上快指针的话,则说明有环
            if (fast == slow) {
                return true;
            }
        }
        return false;
    }

三、拓展

拓展问题一:

如果链表有环,找出环的入口节点。

思路:快慢指针的相遇点到环入口的距离等于头节点到环入口的距离,那么在头节点和相遇点各设一个相同步伐的指针,他们相遇的那个节点就是环入口。

public ListNode getEntrance(ListNode head) {
        ListNode slow = head;
        ListNode fast = head;
        boolean isCycle = false;
        while (fast != null && fast.next != null) {
            fast = fast.next.next;
            slow = slow.next;
            //如果慢指针追赶上快指针的话,则说明有环
            if (fast == slow) {
                isCycle = true;
                break;
            }
        }

        if (isCycle) {
            slow = head;
            while (slow != fast) {
                slow = slow.next;
                fast = fast.next;
            }
            return slow;
        }
        return null;
    }

拓展问题二:

若链表有环,求出环的长度。

思路:若链表有环,得到环入口,然后让指针指向环入口,指针遍历完重新回到环入口的路程即环的长度。

 public int getCylceLength(ListNode head) {
        int length = 0;
        ListNode cycleNode = getEntrance(head);
        if (cycleNode != null) {
            ListNode temp = cycleNode;
            while (true) {
                temp = temp.next;
                length++;
                if (temp == cycleNode) {
                    break;
                }
            }
        }
        return length;
    }

 

全部评论
更多博客请移步于https://blog.csdn.net/qq_33591903
点赞
送花
回复
分享
发布于 2020-03-09 17:46

相关推荐

点赞 收藏 评论
分享
正在热议
# 牛客帮帮团来啦!有问必答 #
1150519次浏览 17147人参与
# 通信和硬件还有转码的必要吗 #
11171次浏览 101人参与
# 不去互联网可以去金融科技 #
20253次浏览 255人参与
# 和牛牛一起刷题打卡 #
18781次浏览 1635人参与
# 实习与准备秋招该如何平衡 #
203293次浏览 3625人参与
# 大厂无回复,继续等待还是奔赴小厂 #
4938次浏览 30人参与
# OPPO开奖 #
19170次浏览 267人参与
# 通信硬件薪资爆料 #
265816次浏览 2484人参与
# 国企是理工四大天坑的最好选择吗 #
2199次浏览 34人参与
# 互联网公司评价 #
97640次浏览 1279人参与
# 简历无回复,你会继续海投还是优化再投? #
25031次浏览 354人参与
# 0offer是寒冬太冷还是我太菜 #
454749次浏览 5123人参与
# 国企和大厂硬件兄弟怎么选? #
53883次浏览 1012人参与
# 参加过提前批的机械人,你们还参加秋招么 #
14628次浏览 349人参与
# 硬件人的简历怎么写 #
82280次浏览 852人参与
# 面试被问第一学历差时该怎么回答 #
19377次浏览 213人参与
# 你见过最离谱的招聘要求是什么? #
27941次浏览 247人参与
# 学历对求职的影响 #
161180次浏览 1804人参与
# 你收到了团子的OC了吗 #
538609次浏览 6386人参与
# 你已经投递多少份简历了 #
344069次浏览 4963人参与
# 实习生应该准时下班吗 #
96945次浏览 722人参与
# 听劝,我这个简历该怎么改? #
63509次浏览 622人参与
牛客网
牛客企业服务