一、 题目
给定一个链表,确定它是否有一个环,不使用额外的空间?
二、 分析
1. 空链表不成环
2. 一个节点自环
3. 一条链表完整成环
思路:使用两个指针,一个每次往前走2步,一个每次往前走1步,两指针一定会相遇,如果两个指针相遇,即说明链表有环存在,时间复杂度为O(N),空间复杂度为O(1)。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
bool hasC......
阅读全文