給定一個(gè)鏈表,返回鏈表開始入環(huán)的第一個(gè)節(jié)點(diǎn)。 如果鏈表無環(huán),則返回 null。
成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比興化網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式興化網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋興化地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。
為了表示給定鏈表中的環(huán),我們使用整數(shù) pos 來表示鏈表尾連接到鏈表中的位置(索引從 0 開始)。 如果 pos 是 -1,則在該鏈表中沒有環(huán)。
說明:不允許修改給定的鏈表。
代碼實(shí)現(xiàn):
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *detectCycle(ListNode *head) {
ListNode *low = head;
ListNode *fast = head;
ListNode *meet = NULL;
while(fast)
{
fast = fast->next;
low = low->next;
if(!fast)
return NULL;
fast = fast->next;
if(low == fast)
{
meet = fast;
break;
}
}
if(meet == NULL)
return NULL;
while(head && meet) //head和meet到達(dá)一定相同的步數(shù)會(huì)在環(huán)的起始點(diǎn)相遇
{
if(head == meet)
{
return head;
}
head = head->next;
meet = meet->next;
}
return NULL;
}
};