赞
踩
目录
题目描述
- bool hasCycle(struct ListNode* head) {
- struct ListNode* fast = head, * slow = head;
-
- while (fast && fast->next)
- {
- fast = fast->next->next;
- slow = slow->next;
-
- if (fast == slow)
- return true;
- }
- return false;
- }
本题是要看链表是否成环,那我们就定义快、慢两个指针,快指针一次走两步,慢指针一次走一步。如果链表是成环的,快指针一定就可以追赶上慢指针,重合后就是成环的;如果链表不成环,那我们的快指针就会走到空。
1、使用快慢指针,初始化都指向原链表的头,慢指针一次走一步,快指针一次走两步;
2、在循环的时候我们加上一条判断语句,fast == slow 时,就说明链表是成环的;
3、如果快指针走到了空,或者快指针的 next 为空时,那就说明链表是不成环的。
*** 本篇结束 ***
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。