您好,登錄后才能下訂單哦!
怎么分析Reverse Linked List,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
Reverse Linked List
反轉一個單鏈表。
示例:
輸入: 1->2->3->4->5->NULL
輸出: 5->4->3->2->1->NULL進階:
你可以迭代或遞歸地反轉鏈表。你能否用兩種方法解決這道題?
設置三個節點pre
、cur
、next
(1)每次查看cur
節點是否為NULL
,如果是,則結束循環,獲得結果
(2)如果cur
節點不是為NULL
,則先設置臨時變量next
為cur
的下一個節點
(3)讓cur
的下一個節點變成指向pre
,而后pre
移動cur
,cur
移動到next
(4)重復(1)(2)(3)
動畫演示GIF有點大,請稍微等待一下加載顯示^_^
1// 206. Reverse Linked List
2// https://leetcode.com/problems/reverse-linked-list/description/
3//
4// 遞歸的方式反轉鏈表
5// 時間復雜度: O(n)
6// 空間復雜度: O(1)
7class Solution {
8public:
9 ListNode* reverseList(ListNode* head) {
10
11 // 遞歸終止條件
12 if(head == NULL || head->next == NULL)
13 return head;
14
15 ListNode* rhead = reverseList(head->next);
16
17 // head->next此刻指向head后面的鏈表的尾節點
18 // head->next->next = head把head節點放在了尾部
19 head->next->next = head;
20 head->next = NULL;
21
22 return rhead;
23 }
24};
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。