欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java 數(shù)據(jù)結(jié)構(gòu)之刪除鏈表中重復(fù)的結(jié)點(diǎn)

 更新時(shí)間:2021年12月11日 10:29:27   作者:2021dragon  
在一個(gè)排序的鏈表中,會(huì)存在重復(fù)的結(jié)點(diǎn),如何實(shí)現(xiàn)刪除該鏈表中重復(fù)的結(jié)點(diǎn),重復(fù)的結(jié)點(diǎn)不保留,并返回鏈表頭指針呢?接下來(lái)小編將帶你詳細(xì)介紹

核心考點(diǎn):鏈表操作,臨界條件檢查,特殊情況處理

在一個(gè)排序的鏈表中,存在重復(fù)的結(jié)點(diǎn),請(qǐng)刪除該鏈表中重復(fù)的結(jié)點(diǎn),重復(fù)的結(jié)點(diǎn)不保留,返回鏈表頭指針。

解析一:(不提倡)

解決該問題較簡(jiǎn)單,且在寫代碼時(shí)不易出錯(cuò)的做法如下:

  1. 遍歷一遍鏈表,記錄重復(fù)結(jié)點(diǎn)的結(jié)點(diǎn)值。
  2. 再遍歷一遍鏈表,逐個(gè)刪除重復(fù)結(jié)點(diǎn)。

動(dòng)圖演示:

該方法需要遍歷兩遍鏈表,且需要開辟額外的內(nèi)存空間存儲(chǔ)重復(fù)結(jié)點(diǎn)的結(jié)點(diǎn)值,所以一般不提倡。

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
        val(x), next(NULL) {
    }
};*/
class Solution {
public:
    ListNode* deleteDuplication(ListNode* pHead) {
        if(pHead == nullptr||pHead->next == nullptr) //鏈表為空或只有一個(gè)結(jié)點(diǎn)無(wú)需進(jìn)行操作
            return pHead;
        ListNode* cur = pHead;
        unordered_set<int> filter;
		//1、遍歷鏈表找出重復(fù)的結(jié)點(diǎn),將結(jié)點(diǎn)值存入filter
		while (cur->next)
        {
			if (cur->val == cur->next->val)
				filter.insert(cur->val);
			cur = cur->next;
        }
		//2、逐個(gè)刪除重復(fù)的結(jié)點(diǎn)
        //先刪除頭部的重復(fù)結(jié)點(diǎn)
        while(pHead&&filter.find(pHead->val) != filter.end())
        {
            pHead = pHead->next;
        }
        if(pHead == nullptr)
            return nullptr;
        //再刪除其余的重復(fù)結(jié)點(diǎn)
        ListNode* prev = pHead;
        ListNode* last = prev->next;
        while(last)
        {
            if(filter.find(last->val) != filter.end())
            {
                prev->next = last->next;
                last = last->next;
            }
            else
            {
                prev = prev->next;
                last = last->next;
            }
        }
        return pHead; //返回鏈表頭指針
    }
};

解析二:(正解)

我們當(dāng)然應(yīng)該盡可能在遍歷一遍鏈表的情況下解決該問題,這時(shí)我們需要使用兩個(gè)指針配合完成,該過程當(dāng)中包含大量細(xì)節(jié),大致步驟如下:

1.為了后續(xù)操作方便,先為該鏈表創(chuàng)建一個(gè)頭結(jié)點(diǎn)。

2.使用指針prev和last遍歷鏈表,初始時(shí)prev指向頭結(jié)點(diǎn),last指向頭結(jié)點(diǎn)的下一個(gè)結(jié)點(diǎn)。

3.當(dāng)last指向的結(jié)點(diǎn)值與其后一個(gè)結(jié)點(diǎn)的結(jié)點(diǎn)值相同時(shí),last獨(dú)自后移,直到last指向結(jié)點(diǎn)的結(jié)點(diǎn)值與其下一個(gè)結(jié)點(diǎn)的結(jié)點(diǎn)值不同為止,此時(shí)讓prev指向的結(jié)點(diǎn)指向last的后一個(gè)結(jié)點(diǎn),最后讓last指向下一個(gè)結(jié)點(diǎn)(圖中未后移)。

4.當(dāng)last指向的結(jié)點(diǎn)值與其后一個(gè)結(jié)點(diǎn)的結(jié)點(diǎn)值不同時(shí),prev和last一同向后移。

如此進(jìn)行下去,直到last將鏈表遍歷完,鏈表當(dāng)中重復(fù)的結(jié)點(diǎn)也就全部被刪除了,最后返回頭結(jié)點(diǎn)指向的鏈表即可。

動(dòng)圖演示:

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
        val(x), next(NULL) {
    }
};*/
class Solution {
public:
	ListNode* deleteDuplication(ListNode* pHead) {
		if (pHead == nullptr || pHead->next == nullptr) //鏈表為空或只有一個(gè)結(jié)點(diǎn)無(wú)需進(jìn)行操作
			return pHead;
		ListNode* head = new ListNode(0); //創(chuàng)建頭結(jié)點(diǎn)(便于操作)
		head->next = pHead; //頭結(jié)點(diǎn)與原鏈表建立關(guān)系
		ListNode* prev = head;
		ListNode* last = prev->next;
		while (last)
		{
			//未發(fā)現(xiàn)重復(fù)的結(jié)點(diǎn),prev和last一同后移
			while (last->next&&last->val != last->next->val)
			{
				prev = prev->next;
				last = last->next;
			}
			//發(fā)現(xiàn)重復(fù)的結(jié)點(diǎn),last獨(dú)自后移
			while (last->next&&last->val == last->next->val)
			{
				last = last->next;
			}
			//到達(dá)此處有三種情況:
			//1、沒有需要?jiǎng)h除的重復(fù)結(jié)點(diǎn),是因?yàn)閘ast->next == nullptr到此
			//2、有需要?jiǎng)h除的重復(fù)結(jié)點(diǎn),是因?yàn)閘ast->next == nullptr到此(鏈表后半段都需要?jiǎng)h除)
			//3、有需要?jiǎng)h除的重復(fù)結(jié)點(diǎn),是因?yàn)閘ast->val != last->next->val到此(鏈表中間某段需要?jiǎng)h除)
			if (prev->next != last) //說明有需要?jiǎng)h除的重復(fù)結(jié)點(diǎn)
			{
				prev->next = last->next;
			}
			last = last->next;
		}
		return head->next; //返回鏈表頭指針
	}
}; 

到此這篇關(guān)于Java 數(shù)據(jù)結(jié)構(gòu)之刪除鏈表中重復(fù)的結(jié)點(diǎn)的文章就介紹到這了,更多相關(guān)Java 刪除鏈表重復(fù)結(jié)點(diǎn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring源碼解析 Bean屬性填充

    Spring源碼解析 Bean屬性填充

    這篇文章主要介紹了Spring源碼解析 Bean屬性填充,文章圍繞主題展開想詳細(xì)的內(nèi)容詳情,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • Java 超詳細(xì)講解ThreadLocal類的使用

    Java 超詳細(xì)講解ThreadLocal類的使用

    寫SpringBoot項(xiàng)目的時(shí)候,經(jīng)常用到的一個(gè)保存用戶信息的類就是Threadlocal,我們今天就來(lái)詳細(xì)介紹一下這個(gè)類,感興趣的朋友來(lái)看看吧
    2022-04-04
  • Spring中的ConversionService源碼解析

    Spring中的ConversionService源碼解析

    這篇文章主要介紹了Spring中的ConversionService源碼解析,ConversionService是類型轉(zhuǎn)換服務(wù)的接口,從名字就可以看出ConverterRegistry是要實(shí)現(xiàn)轉(zhuǎn)換器注冊(cè)表的接口,添加和移除Converter和GenericConverter,需要的朋友可以參考下
    2023-11-11
  • Java實(shí)現(xiàn)TopK問題的方法

    Java實(shí)現(xiàn)TopK問題的方法

    這篇文章主要介紹了Java實(shí)現(xiàn)TopK問題的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 深入理解Swift中的Substring和String

    深入理解Swift中的Substring和String

    這篇文章主要給大家深入的介紹了Swift中Substring和String的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • Spring中一個(gè)少見的引介增強(qiáng)IntroductionAdvisor

    Spring中一個(gè)少見的引介增強(qiáng)IntroductionAdvisor

    這篇文章主要為大家介紹了Spring中一個(gè)少見的引介增強(qiáng)IntroductionAdvisor實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • mybatis-plus雪花算法自動(dòng)生成機(jī)器id原理及源碼

    mybatis-plus雪花算法自動(dòng)生成機(jī)器id原理及源碼

    Mybatis-Plus是一個(gè)Mybatis的增強(qiáng)工具,它在Mybatis的基礎(chǔ)上做了增強(qiáng),卻不做改變,Mybatis-Plus是為簡(jiǎn)化開發(fā)、提高開發(fā)效率而生,但它也提供了一些很有意思的插件,比如SQL性能監(jiān)控、樂觀鎖、執(zhí)行分析等,下面一起看看mybatis-plus雪花算法自動(dòng)生成機(jī)器id原理解析
    2021-06-06
  • Spring?Data?JPA映射自定義實(shí)體類操作

    Spring?Data?JPA映射自定義實(shí)體類操作

    這篇文章主要介紹了Spring?Data?JPA映射自定義實(shí)體類操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • 快速校驗(yàn)實(shí)體類時(shí),@Valid,@Validated,@NotNull注解無(wú)效的解決

    快速校驗(yàn)實(shí)體類時(shí),@Valid,@Validated,@NotNull注解無(wú)效的解決

    這篇文章主要介紹了快速校驗(yàn)實(shí)體類時(shí),@Valid,@Validated,@NotNull注解無(wú)效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • java使用多線程讀取超大文件

    java使用多線程讀取超大文件

    這篇文章主要為大家詳細(xì)介紹了java使用多線程讀取超大文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08

最新評(píng)論