首页 > 其他 > 详细

leetcode--Linked List Cycle

时间:2014-02-12 12:30:11      阅读:340      评论:0      收藏:0      [点我收藏+]

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

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
/**
 * 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) {
        boolean hasCycle = true;
        if(head == null)
            hasCycle = false;
        else{
            ListNode first = head;
            ListNode second = head;
            do{
                if(second.next == null || second.next.next == null){
                    hasCycle = false;
                    break;
                }  
                else{
                    first = first.next;
                    second = second.next;
                    second = second.next;
                }
            }while(first != second);
        }
        return hasCycle;
    }
}

  

leetcode--Linked List Cycle

原文:http://www.cnblogs.com/averillzheng/p/3545282.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!