編碼實(shí)現(xiàn)從無序鏈表中移除重復(fù)項(xiàng)(C和JAVA實(shí)例)
如果不能使用臨時(shí)緩存,你怎么編碼實(shí)現(xiàn)?
方法一:不使用額外的存儲(chǔ)空間,直接在原始鏈表上進(jìn)行操作。首先用一個(gè)指針指向鏈表頭節(jié)點(diǎn)開始,然后遍歷其后面的節(jié)點(diǎn),將與該指針?biāo)腹?jié)點(diǎn)數(shù)據(jù)相同的節(jié)點(diǎn)刪除。然后將該指針后移一位,繼續(xù)上述操作。直到該指針移到鏈表。
void delete_duplicate1(node* head){
node*pPos=head->next;
node*p,*q;
while(pPos!=NULL){//用pPos指針來指示當(dāng)前移動(dòng)到什么位置了
p=pPos;
q=pPos->next;
while(q!=NULL){//遍歷pPos后面的所有節(jié)點(diǎn),找出節(jié)點(diǎn)值與pPos所指節(jié)點(diǎn)相同的節(jié)點(diǎn),將其刪除
if(pPos->data==q->data){
node*pDel=q;
p->next=q->next;
q=p->next;
free(pDel);
}
else{
p=q;
q=q->next;
}
}
pPos=pPos->next;
}
}
方法二:如果允許使用額外的空間,則能通過空間換時(shí)間,來降低算法的復(fù)制度??梢允褂胔ash表來完成,既然是面試題,我們這里可以暫時(shí)先不考慮使用hash可能帶來的一些問題,先假設(shè)它是完美的。即假設(shè)它能將任意整數(shù)hash到一定范圍,不會(huì)出現(xiàn)負(fù)數(shù)下標(biāo),不會(huì)出現(xiàn)hash沖突等。
void delete_duplicate2(node* head)
{
node*p=head->next;
node*q=p->next;
memset(hash,0,sizeof(hash));
hash[p->data]=1;//置為1,表示該數(shù)已經(jīng)出現(xiàn)過
while(q!=NULL){
if(hash[q->data]!=0){
node*pDel=q;
p->next=q->next;
q=p->next;
free(pDel);
}
else{
hash[q->data]=1;//置為1,表示該數(shù)已經(jīng)出現(xiàn)過
p=q;
q=q->next;
}
}
}
JAVA參考代碼:
public static void deleteDups(LinkedListNode n) {
Hashtable table = new Hashtable();
LinkedListNode previous = null;
while (n != null) {
if (table.containsKey(n.data)) previous.next = n.next;
else {
table.put(n.data, true);
previous = n;
}
n = n.next;
}
}
public static void deleteDups2(LinkedListNode head) {
if (head == null) return;
LinkedListNode previous = head;
LinkedListNode current = previous.next;
while (current != null) {
LinkedListNode runner = head;
while (runner != current) { // Check for earlier dups
if (runner.data == current.data) {
LinkedListNode tmp = current.next; // remove current
previous.next = tmp;
current = tmp; // update current to next node
break; // all other dups have already been removed
}
runner = runner.next;
}
if (runner == current) { // current not updated - update now
previous = current;
current = current.next;
}
}
}
- Java模擬單鏈表和雙端鏈表數(shù)據(jù)結(jié)構(gòu)的實(shí)例講解
- java實(shí)現(xiàn)單鏈表、雙向鏈表
- Java實(shí)現(xiàn)雙向鏈表(兩個(gè)版本)
- java實(shí)現(xiàn)單鏈表之逆序
- java中使用雙向鏈表實(shí)現(xiàn)貪吃蛇程序源碼分享
- Java采用循環(huán)鏈表結(jié)構(gòu)求解約瑟夫問題
- java實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)單鏈表示例(java單鏈表)
- java雙向循環(huán)鏈表的實(shí)現(xiàn)代碼
- Java語言中鏈表和雙向鏈表
- Java模擬有序鏈表數(shù)據(jù)結(jié)構(gòu)的示例
相關(guān)文章
Java web.xml之contextConfigLocation作用案例詳解
這篇文章主要介紹了Java web.xml之contextConfigLocation作用案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能
這篇文章主要介紹了Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
詳解Spring中@Component和@Configuration的區(qū)別
一直有同學(xué)搞不清Spring中@Component和@Configuration這兩個(gè)注解有什么區(qū)別,所以這篇文章小編就給大家簡單介紹一下@Component和@Configuration的區(qū)別,需要的朋友可以參考下2023-07-07
xxl-job定時(shí)任務(wù)配置應(yīng)用及添加到springboot項(xiàng)目中實(shí)現(xiàn)動(dòng)態(tài)API調(diào)用
XXL-JOB是一個(gè)分布式任務(wù)調(diào)度平臺(tái),其核心設(shè)計(jì)目標(biāo)是開發(fā)迅速、學(xué)習(xí)簡單、輕量級(jí)、易擴(kuò)展,本篇文章主要是對(duì)xuxueli的xxl-job做一個(gè)簡單的配置,以及將其添加到自己已有的項(xiàng)目中進(jìn)行api調(diào)用,感興趣的朋友跟隨小編一起看看吧2024-04-04
MyBatis-Plus實(shí)現(xiàn)邏輯刪除功能解析
這篇文章主要介紹了MyBatis-Plus實(shí)現(xiàn)邏輯刪除功能解析,有時(shí)候并不需要真正的刪除數(shù)據(jù),而是想邏輯刪除,方便數(shù)據(jù)恢復(fù),MyBatis-Plus可以很方便的實(shí)現(xiàn)邏輯刪除的功能,需要的朋友可以參考下2023-11-11

