141 环形链表
要求使用空間復(fù)雜度為O(1)的方法,可是我并沒有想到。我想到的只有用一個(gè)哈希表記錄一下所有訪問過的節(jié)點(diǎn)。
題解給出的空間復(fù)雜度為O(1)的方法是使用兩個(gè)指針,然后讓一個(gè)一次跑一步,一個(gè)一次跑兩步,如果跑的快的能追上跑的慢的就是有環(huán),如果跑得快的跑到了鏈表的末尾就是沒有環(huán)。設(shè)置跑的快的比跑的慢的多跑一步,這樣對(duì)一個(gè)長度至多為N的環(huán),總會(huì)追上的,時(shí)間復(fù)雜度為O(N)。
需要注意處理循環(huán)條件,并且因?yàn)榕艿目斓墓?jié)點(diǎn)每次要跑兩步,要處理如果沒有環(huán)跑的快的節(jié)點(diǎn)跑一步就跑到結(jié)尾的情況。
/*** 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) {if(head == nullptr || head -> next == nullptr) return false;ListNode *slow = head, *quick = head;do{slow = slow -> next;quick = quick -> next;if(quick != nullptr) quick = quick ->next;if(quick == nullptr) return false;}while(quick != slow);return true;} };總結(jié)
- 上一篇: 双侧积水输卵管症状
- 下一篇: lol里的慎用E闪是否还会有嘲讽效果?