日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

LeetCode 142——环形链表 II

發布時間:2024/9/21 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode 142——环形链表 II 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1. 題目

2. 解答

2.1 方法 1

定義快慢兩個指針,慢指針每次前進一步,快指針每次前進兩步,若鏈表有環,則快慢指針一定會相遇。

當快慢指針相遇時,我們讓慢指針指向頭節點,快指針不變,然后每次快慢指針都前進一步,當兩個指針再次相遇時,兩個指針所指向的節點就是入環節點。

將鏈表的環向后展開,如上圖所示,假設第一次相遇時慢指針走過了 a 個節點,即圖中 s 節點,可知此時快指針指向同一個節點,即圖中的 f 節點。

然后,假設慢指針從鏈表頭到入環節點共有 b 個節點,快指針從快慢指針相遇節點到入環節點共有 c 個節點。那么可知第一次相遇時,快指針走過了 a+c+a-b 個節點,這應該是慢指針走過節點數的兩倍,也即 a+c+a-b = 2a,所以有 b=c。

/*** 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 *slow = head;ListNode *fast = head;while (fast && fast->next){slow = slow->next;fast = fast->next->next;if (slow == fast) break;}if (fast && fast->next){slow = head;while (slow != fast){slow = slow->next;fast = fast->next;}return slow;}return NULL;} };
2.2 方法 2

用 unordered_map 充當散列表的功能,每次將鏈表的節點指針作為鍵值存入 map,如果檢測到當前節點指針已經存在于 map 中則說明當前節點指針即為鏈表入環的第一個節點。

class Solution { public:ListNode *detectCycle(ListNode *head) {unordered_map<ListNode *, char> nodemap;ListNode *temp = head;while (temp){// 當前節點已存在于 map 中,即為鏈表入環的第一個節點if (nodemap.count(temp) == 1) return temp;nodemap[temp] = '0';temp = temp->next;}return NULL;} };

獲取更多精彩,請關注「seniusen」!

總結

以上是生活随笔為你收集整理的LeetCode 142——环形链表 II的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。