本文小編為大家詳細(xì)介紹“C++怎么移除有序鏈表中的重復(fù)項(xiàng)”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“C++怎么移除有序鏈表中的重復(fù)項(xiàng)”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識(shí)吧。
創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的懷來網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
Given a sorted linked list, delete all duplicates such that each element appear only once.
Example 1:
Input: 1->1->2
Output: 1->2
Example 2:
Input: 1->1->2->3->3
Output: 1->2->3
這道題讓我們移除給定有序鏈表的重復(fù)項(xiàng),那么可以遍歷這個(gè)鏈表,每個(gè)結(jié)點(diǎn)和其后面的結(jié)點(diǎn)比較,如果結(jié)點(diǎn)值相同了,只要將前面結(jié)點(diǎn)的 next 指針跳過緊挨著的相同值的結(jié)點(diǎn),指向后面一個(gè)結(jié)點(diǎn)。這樣遍歷下來,所有重復(fù)的結(jié)點(diǎn)都會(huì)被跳過,留下的鏈表就是沒有重復(fù)項(xiàng)的了,代碼如下:
解法一:
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; } };
我們也可以使用遞歸的方法來做,首先判斷是否至少有兩個(gè)結(jié)點(diǎn),若不是的話,直接返回 head。否則對(duì) head->next 調(diào)用遞歸函數(shù),并賦值給 head->next。這里可能比較暈,先看后面一句,返回的時(shí)候,head 結(jié)點(diǎn)先跟其身后的結(jié)點(diǎn)進(jìn)行比較,如果值相同,那么返回后面的一個(gè)結(jié)點(diǎn),當(dāng)前的 head 結(jié)點(diǎn)就被跳過了,而如果不同的話,還是返回 head 結(jié)點(diǎn)??梢园l(fā)現(xiàn)了,進(jìn)行實(shí)質(zhì)上的刪除操作是在最后一句進(jìn)行了,再來看第二句,對(duì) head 后面的結(jié)點(diǎn)調(diào)用遞歸函數(shù),那么就應(yīng)該 suppose 返回來的鏈表就已經(jīng)沒有重復(fù)項(xiàng)了,此時(shí)接到 head 結(jié)點(diǎn)后面,在第三句的時(shí)候再來檢查一下 head 是否又 duplicate 了,實(shí)際上遞歸一直走到了末尾結(jié)點(diǎn),再不斷的回溯回來,進(jìn)行刪除重復(fù)結(jié)點(diǎn),參見代碼如下:
解法二:
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++怎么移除有序鏈表中的重復(fù)項(xiàng)”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
新聞名稱:C++怎么移除有序鏈表中的重復(fù)項(xiàng)
文章起源:http://jinyejixie.com/article10/gpesgo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、小程序開發(fā)、App開發(fā)、移動(dòng)網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)、外貿(mào)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)