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

Linked list cycle

时间:2014-11-20 13:31:10      阅读:181      评论:0      收藏:0      [点我收藏+]

标签:io   ar   sp   java   for   on   bs   ad   amp   

Given a linked list, determine if it has a cycle in it. (Without using eatra space)

//Solution: define two pointers, one moves one step each time while the other moves two steps. If the second one catches the first at some point, return true.

Java:

/** 
 * Definition for singly-linked list. 
 * class ListNode { 
 *     int val; 
 *     ListNode next; 
 *     ListNode(int x) { 
 *         val = x; 
 *         next = null; 
 *     } 
 * } 
 */ 
public class Solution { 
    public boolean hasCycle(ListNode head) { 
        if(head==null) 
            return false; 
        ListNode first = head; 
        ListNode second = head; 
        while (first.next!=null && second.next!=null && second.next.next!=null){               //remember to check second.next first 
            first = first.next; 
            second = second.next.next; 
            if(first==second) 
                return true; 
        } 
        return false; 
  
    } 
}

 

 

Python:

# Definition for singly-linked list. 
# class ListNode: 
#     def __init__(self, x): 
#         self.val = x 
#         self.next = None 
 
class Solution: 
    # @param head, a ListNode 
    # @return a boolean 
    def hasCycle(self, head): 
        if head==None: 
            return False 
        first = head 
        second = head 
        while first.next!=None and second.next!=None and second.next.next!=None: 
            first = first.next 
            second = second.next.next 
            if first==second: 
                return True 
        return False

Linked list cycle

标签:io   ar   sp   java   for   on   bs   ad   amp   

原文地址:http://www.cnblogs.com/cs-jack-cheng/p/4110349.html

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