亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

C++如何移除有序鏈表中的重復項

發布時間:2022-03-28 13:49:41 來源:億速云 閱讀:373 作者:iii 欄目:大數據

這篇文章主要講解了“C++如何移除有序鏈表中的重復項”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“C++如何移除有序鏈表中的重復項”吧!

移除有序鏈表中的重復項

Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list.

Example 1:

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

Example 2:

Input: 1->1->1->2->3
Output: 2->3

和之前那道 Remove Duplicates from Sorted List 不同的地方是這里要刪掉所有的重復項,由于鏈表開頭可能會有重復項,被刪掉的話頭指針會改變,而最終卻還需要返回鏈表的頭指針。所以需要定義一個新的節點,然后鏈上原鏈表,然后定義一個前驅指針和一個現指針,每當前驅指針指向新建的節點,現指針從下一個位置開始往下遍歷,遇到相同的則繼續往下,直到遇到不同項時,把前驅指針的next指向下面那個不同的元素。如果現指針遍歷的第一個元素就不相同,則把前驅指針向下移一位。代碼如下:

解法一:

class Solution {
public:
    ListNode* deleteDuplicates(ListNode* head) {
        ListNode *cur = head;
        while (cur && cur->next) {
            if (cur->val == cur->next->val) {
                cur->next = cur->next->next;
            } else {
                cur = cur->next;
            }
        }
        return head;
    }
};

同樣,我們也可以使用遞歸來做,首先判空,如果 head 為空,直接返回。然后判斷,若 head 之后的結點存在,且值相等,那么先進行一個 while 循環,跳過后面所有值相等的結點,到最后一個值相等的點停下。比如對于例子2來說,head 停在第三個結點1處,然后對后面一個結點調用遞歸函數,即結點2,這樣做的好處是,返回的值就完全把所有的結點1都刪掉了。若 head 之后的結點值不同,那么還是對 head 之后的結點調用遞歸函數,將返回值連到 head 的后面,這樣 head 結點還是保留下來了,因為值不同嘛,最后返回 head 即可,參見代碼如下:

解法二:

class Solution {
public:
    ListNode* deleteDuplicates(ListNode* head) {
        if (!head || !head->next) return head;
        head->next = deleteDuplicates(head->next);
        return (head->val == head->next->val) ? head->next : head;
    }
};

感謝各位的閱讀,以上就是“C++如何移除有序鏈表中的重復項”的內容了,經過本文的學習后,相信大家對C++如何移除有序鏈表中的重復項這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

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

c++
AI

青铜峡市| 菏泽市| 赤水市| 阜平县| 泸溪县| 油尖旺区| 琼海市| 霍山县| 沅陵县| 麻城市| 济源市| 龙岩市| 天峨县| 富蕴县| 景东| 凤城市| 洛扎县| 阿瓦提县| 定州市| 崇义县| 诸城市| 白玉县| 项城市| 冷水江市| 合山市| 兰溪市| 竹溪县| 韶关市| 双城市| 河曲县| 工布江达县| 连平县| 辽阳市| 紫云| 平度市| 定襄县| 南江县| 如东县| 安塞县| 永泰县| 新化县|