141. Linked List Cycle

题目141. Linked List Cycle

Given a linked list, determine if it has a cycle in it.
Follow up:
Can you solve it without using extra space?
思路:使用快慢指针, fast每次跳两个节点,low一次跳一个节点,如果fast或者low最后为null,说明
链表没有节点. 如果fast和low相等,那么说明链表存在环
public class Solution {
    public boolean hasCycle(ListNode head) {
        if(head == null){
            return false;
        }
        
        ListNode lowerNode = head;
        ListNode fastNode = head;
        while(lowerNode != null && fastNode != null){
            if(fastNode.next == null){
                return false;
            }
            fastNode = fastNode.next.next;
            lowerNode = lowerNode.next;
            if(lowerNode == fastNode){
                return true;
            }
        }
        return false;
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容