中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

C++怎么移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)

這篇文章主要介紹了C++怎么移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇C++怎么移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)文章都會有所收獲,下面我們一起來看看吧。

成都創(chuàng)新互聯(lián)從2013年創(chuàng)立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)制作、成都做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢想脫穎而出為使命,1280元章丘做網(wǎng)站,已為上家服務(wù),為章丘各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:13518219792

移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)

Given a linked list, remove the nth node from the end of list and return its head.

For example,

C++怎么移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)

Given linked list: 1->2->3->4->5, and n = 2.

After removing the second node from the end, the linked list becomes 1->2->3->5.

Note:
Given n will always be valid.
Try to do this in one pass.

這道題讓我們移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn),限定n一定是有效的,即n不會大于鏈表中的元素總數(shù)。還有題目要求一次遍歷解決問題,那么就得想些比較巧妙的方法了。比如首先要考慮的時(shí),如何找到倒數(shù)第N個(gè)節(jié)點(diǎn),由于只允許一次遍歷,所以不能用一次完整的遍歷來統(tǒng)計(jì)鏈表中元素的個(gè)數(shù),而是遍歷到對應(yīng)位置就應(yīng)該移除了。那么就需要用兩個(gè)指針來幫助解題,pre 和 cur 指針。首先 cur 指針先向前走N步,如果此時(shí) cur 指向空,說明N為鏈表的長度,則需要移除的為首元素,那么此時(shí)返回 head->next 即可,如果 cur 存在,再繼續(xù)往下走,此時(shí) pre 指針也跟著走,直到 cur 為最后一個(gè)元素時(shí)停止,此時(shí) pre 指向要移除元素的前一個(gè)元素,再修改指針跳過需要移除的元素即可,參見代碼如下:

方式一:

class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
        if (!head->next) return NULL;
        ListNode *pre = head, *cur = head;
        for (int i = 0; i < n; ++i) cur = cur->next;
        if (!cur) return head->next;
        while (cur->next) {
            cur = cur->next;
            pre = pre->next;
        }
        pre->next = pre->next->next;
        return head;
    }
};

方式二:

class Solution {
public:
    int getLength(ListNode* head) {
        int length = 0;
        while (head) {
            ++length;
            head = head->next;
        }
        return length;
    }

    ListNode* removeNthFromEnd(ListNode* head, int n) {
        ListNode* dummy = new ListNode(0, head);
        int length = getLength(head);
        ListNode* cur = dummy;
        for (int i = 1; i < length - n + 1; ++i) {
            cur = cur->next;
        }
        cur->next = cur->next->next;
        ListNode* ans = dummy->next;
        delete dummy;
        return ans;
    }
};

關(guān)于“C++怎么移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“C++怎么移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章題目:C++怎么移除鏈表倒數(shù)第N個(gè)節(jié)點(diǎn)
本文地址:http://www.rwnh.cn/article48/jsdphp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器營銷型網(wǎng)站建設(shè)、企業(yè)網(wǎng)站制作網(wǎng)站設(shè)計(jì)、網(wǎng)頁設(shè)計(jì)公司、定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
鹤庆县| 平陆县| 保康县| 隆子县| 抚远县| 平顶山市| 扎鲁特旗| 边坝县| 敖汉旗| 衢州市| 河北省| 哈巴河县| 南平市| 千阳县| 浪卡子县| 富锦市| 阳原县| 新宁县| 阳城县| 余干县| 荃湾区| 肇源县| 怀安县| 东乌珠穆沁旗| 白玉县| 田阳县| 陆河县| 洪湖市| 资讯| 舞阳县| 临沧市| 永州市| 东乌| 曲麻莱县| 长子县| 龙陵县| 穆棱市| 嘉禾县| 赤城县| 海丰县| 新竹县|