您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
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?
题目大意:
判断一个单链表是否存在环。
思路:
采用快慢指针来处理。
代码如下:
/** * 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) { ListNode *slow,*fast; if(NULL == head || NULL == head->next) return false; slow = head; fast = head; fast = fast->next->next; slow = slow->next; while(1) { if(fast == NULL || fast->next == NULL) return false; if(fast == slow || fast->next == slow) return true; slow = slow->next; fast = fast->next->next; } return false; } };
总结:快慢指针
快慢指针中的快慢指的是移动的步长,即每次向前移动速度的快慢。例如可以让快指针每次沿链表向前移动2,慢指针每次向前移动1次。
快慢指针可以用来求一个单链表是否存在环,还可以用来求一个单链表的中间位置。
2016-08-13 00:34:46
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。