码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode] Linked List Cycle

时间:2015-06-23 17:44:18      阅读:99      评论:0      收藏:0      [点我收藏+]

标签:

Given a linked list, determine if it has a cycle in it.

Follow up:
Can you solve it without using extra space?

 

Hide Tags
 Linked List Two Pointers
 
 
分析:经典的快慢指针法:
 
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
    public:
        bool hasCycle(ListNode *head)
        {   
            if(head == NULL)
                return false;

            ListNode* slow = head->next;
            ListNode* fast = NULL;

            if(slow)
                fast = slow->next;

            while(fast && slow)
            {   
                if(fast == slow)
                    return true;
                if(fast->next && fast->next->next)
                    fast = fast->next->next;
                else //reach the end
                    return false;
                slow = slow->next;
            }   
            return false;
        }   
};

 

 

[LeetCode] Linked List Cycle

标签:

原文地址:http://www.cnblogs.com/diegodu/p/4595685.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!