91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++如何實現LeetCode

發布時間:2021-07-09 11:05:17 來源:億速云 閱讀:168 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關C++如何實現LeetCode的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

[LeetCode] Reverse Linked List 倒置鏈表

Reverse a singly linked list.

Example:

Input: 1->2->3->4->5->NULL
Output: 5->4->3->2->1->NULL

Follow up:

A linked list can be reversed either iteratively or recursively. Could you implement both?

 之前做到 Reverse Linked List II 的時候我還納悶怎么只有二沒有一呢,原來真是忘了啊,現在才加上,這道題跟之前那道比起來簡單不少,題目為了增加些許難度,讓我們分別用迭代和遞歸來實現,但難度還是不大。我們先來看迭代的解法,思路是在原鏈表之前建立一個空的newHead,因為首節點會變,然后從head開始,將之后的一個節點移到newHead之后,重復此操作直到head成為末節點為止,代碼如下:

解法一:

class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        ListNode *newHead = NULL;
        while (head) {
            ListNode *t = head->next;
            head->next = newHead;
            newHead = head;
            head = t;
        }
        return newHead;
    }
};

下面我們來看遞歸解法,代碼量更少,遞歸解法的思路是,不斷的進入遞歸函數,直到head指向倒數第二個節點,因為head指向空或者是最后一個結點都直接返回了,newHead則指向對head的下一個結點調用遞歸函數返回的頭結點,此時newHead指向最后一個結點,然后head的下一個結點的next指向head本身,這個相當于把head結點移動到末尾的操作,因為是回溯的操作,所以head的下一個結點總是在上一輪被移動到末尾了,但head之后的next還沒有斷開,所以可以順勢將head移動到末尾,再把next斷開,最后返回newHead即可,代碼如下:

解法二:

class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        if (!head || !head->next) return head;
        ListNode *newHead = reverseList(head->next);
        head->next->next = head;
        head->next = NULL;
        return newHead;
    }
};

感謝各位的閱讀!關于“C++如何實現LeetCode”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

河间市| 绵阳市| 叶城县| 东阳市| 高密市| 祁门县| 遵义县| 阿荣旗| 阳东县| 察雅县| 托克托县| 禄劝| 新乡县| 泰安市| 项城市| 东海县| 海伦市| 上高县| 武夷山市| 清流县| 鹤壁市| 林州市| 上杭县| 濉溪县| 锡林郭勒盟| 呼图壁县| 青海省| 长武县| 荥阳市| 文化| 安塞县| 惠安县| 阳城县| 呈贡县| 开化县| 元阳县| 南宫市| 长沙市| 都江堰市| 福清市| 宾阳县|