您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“Java刪除值相同的多余結(jié)點(diǎn)的算法是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
這是一道算法題,寫(xiě)算法題最恨沒(méi)有圖解,懂的人不需要看你的文章,不懂的你再怎么講解也沒(méi)有幾張圖解來(lái)得簡(jiǎn)單易懂,下面來(lái)分析一下這道題。
我暫時(shí)還沒(méi)有更好的解決方案,雖然有一個(gè)辦法解決,但是時(shí)間復(fù)雜度有點(diǎn)高,先看看我的思路吧。
看圖解:
p -> data == q -> next -> data
;若不相等,則讓q指向下一個(gè)結(jié)點(diǎn):
p = p->next
;若相等,則應(yīng)該先保存下一個(gè)結(jié)點(diǎn):
r = q -> next
,然后讓q指針指向下一個(gè)結(jié)點(diǎn)的下一個(gè)結(jié)點(diǎn):
q = r -> next
,并釋放r指向的結(jié)點(diǎn)內(nèi)存。這樣就成功刪除了一個(gè)與首元結(jié)點(diǎn)重復(fù)的結(jié)點(diǎn),接下來(lái)以同樣的方式繼續(xù)比較,直到整個(gè)單鏈表都遍歷完畢,此時(shí)單鏈表中已無(wú)與首元結(jié)點(diǎn)重復(fù)的結(jié)點(diǎn);然后我們就要修改p指針的指向,讓其指向首元結(jié)點(diǎn)的下一個(gè)結(jié)點(diǎn),再讓q指向其下一個(gè)結(jié)點(diǎn),繼續(xù)遍歷,將單鏈表中與第二個(gè)結(jié)點(diǎn)重復(fù)的所有結(jié)點(diǎn)刪除。以此類(lèi)推,直至指針p也遍歷完了整個(gè)單鏈表,則算法結(jié)束。
剛才我們已經(jīng)刪除了一個(gè)結(jié)點(diǎn),那么接下來(lái)p應(yīng)該指向下一個(gè)結(jié)點(diǎn)了:
q = q -> next
。
代碼如下:
LinkList DeleteRepeat(LinkList l){
LinkList p,q,r;
p = l->next;
while(p != NULL){
q = p;
while(q->next != NULL){
if(p->data == q->next->data){
r = q->next;
q = r->next;
free(r);
}else{
q = q->next;
}
}
p = p->next;
}
return l;
}
“Java刪除值相同的多余結(jié)點(diǎn)的算法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。