C語言實現(xiàn)單鏈表實現(xiàn)方法
C語言實現(xiàn)單鏈表實現(xiàn)方法
鏈表和我們之前實現(xiàn)過的順序表一樣,都是簡單的數(shù)據(jù)結(jié)構(gòu),鏈表分為單向鏈表、雙向鏈表、循環(huán)鏈表。而單向鏈表又分為兩種實現(xiàn)方法,一種為帶頭節(jié)點(diǎn)的單鏈表,一種為不帶頭節(jié)點(diǎn)的單鏈表。我們來具體看看不帶頭節(jié)點(diǎn)的單鏈表的實現(xiàn)
單鏈表:它是一種鏈?zhǔn)酱鎯Φ木€性表,用一組地址任意的存儲單元存放線性表的數(shù)據(jù)元素,稱存儲單元為一個節(jié)點(diǎn)。
今天我們來實現(xiàn)一些單鏈表的簡單接口
先看看單鏈表的結(jié)構(gòu): (為了通用性,我們將類型重命名為DataType)
typedef int DataType; //鏈表 typedef struct Node { DataType *data; struct Node *next; }Node, *pNode, *pList;
接下來看看我們要實現(xiàn)的接口:
void InitLinkList(pList *pplist);//初始化鏈表 pNode BuyNode(DataType d);//創(chuàng)建鏈表節(jié)點(diǎn) void PushBack(pList *pplist, DataType d);//尾插 void PopBack(pList *pplist);//尾刪 void PushFront(pList *pplist, DataType d);//頭插 void PopFront(pList *pplist);//頭刪 void PrintList(pList plist);//打印鏈表 pNode Find(pList plist, DataType d);//查找指定元素 void Remove(pList *pplist, DataType d);//刪除指定的一個元素 void RemoveAll(pList *pplist, DataType d);//刪除指定的所有元素 void Insert(pList *pplist, pNode pos, DataType d);//指定位置的后面插入 void Erase(pList *pplist, pNode pos);//指定位置刪除 void DestroyList(pList *pplist);//銷毀鏈表
來看看每個接口的具體實現(xiàn):
pNode BuyNode(DataType d) { pNode newNode = (pNode)malloc(sizeof(Node)); if (newNode == NULL) { perror("malloc"); exit(EXIT_FAILURE); } newNode->data = d; newNode->next = NULL; return newNode; } void InitLinkList(pList *pplist) { assert(pplist); *pplist = NULL; } void PushBack(pList *pplist, DataType d) { assert(pplist); pNode newNode = BuyNode(d); pNode cur = *pplist; //鏈表沒有節(jié)點(diǎn) if (*pplist == NULL) { *pplist = newNode; return; } //鏈表有節(jié)點(diǎn) while (cur->next != NULL) { cur = cur->next; } cur->next = newNode; } void PopBack(pList *pplist) { pNode cur = *pplist; pNode prev = NULL; assert(pplist); //鏈表沒有節(jié)點(diǎn) if (*pplist == NULL) { return; } //鏈表有一個節(jié)點(diǎn) if (cur->next == NULL) { free(*pplist); *pplist = NULL; return; } //鏈表有兩個及兩個以上節(jié)點(diǎn) while (cur->next != NULL) { prev = cur;//prev中保存的是cur之前的那個節(jié)點(diǎn) cur = cur->next; } prev->next = NULL; free(cur); } void PushFront(pList *pplist, DataType d) { pNode newNode = BuyNode(d); //pNode cur = *pplist; assert(pplist); ////鏈表沒有節(jié)點(diǎn) //if (*pplist == NULL) //{ // *pplist = newNode; //} ////鏈表有節(jié)點(diǎn) newNode->next = *pplist; *pplist = newNode; } void PopFront(pList *pplist) { pNode cur = *pplist; assert(pplist); //鏈表為空 if (*pplist == NULL) { return; } *pplist = cur->next; free(cur); cur = NULL; } void PrintList(pList plist) { pNode cur = plist; while (cur) { printf("%d-->", cur->data); cur = cur->next; } printf("NULL\n"); } pNode Find(pList plist, DataType d) { pNode cur = plist; while (cur) { if (cur->data == d) { return cur; } cur = cur->next; } return NULL; } void Remove(pList *pplist, DataType d) { pNode cur = *pplist; pNode prev = NULL; assert(pplist); if (cur == NULL) { return; } while (cur) { if (cur->data == d) { pNode del = cur; if (cur == *pplist) { *pplist = cur->next; } prev->next = cur->next; free(del); del = NULL; return; } else { prev = cur; cur = cur->next; } } } void RemoveAll(pList *pplist, DataType d) { pNode cur = *pplist; pNode prev = NULL; assert(pplist); if (*pplist == NULL) { return; } while (cur) { if (cur->data == d) { pNode del = cur; if (cur == *pplist) { *pplist = cur->next; } else { prev->next = cur->next; } cur = cur->next; free(del); del = NULL; } else { prev = cur; cur = cur->next; } } } //在pos后面插入一個元素 void Insert(pList *pplist, pNode pos, DataType d) { pNode newNode = BuyNode(d); assert(pplist); assert(pos); if (*pplist == NULL) { PushFront(pplist, d); return; } newNode->next = pos->next; pos->next = newNode; } void Erase(pList *pplist, pNode pos) { assert(pplist); assert(pos); //要刪除的是尾節(jié)點(diǎn) if (pos->next == NULL) { PopBack(pplist); } //刪除的是非尾節(jié)點(diǎn) else { pNode del = pos->next; pos->data = pos->next->data; pos->next = pos->next->next; free(del); del = NULL; } } void DestroyList(pList *pplist) { assert(pplist); pNode cur = *pplist; while (cur) { pNode del = cur; cur = cur->next; printf("del:%d\n", del->data); free(del); del = NULL; } }
由于這些接口都較為簡單,所以不進(jìn)行具體的測試展示,讀者可以自行測試
以上就是C語言實現(xiàn)單鏈表實現(xiàn)方法,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)與定點(diǎn)概述
本文主要介紹DSP中浮點(diǎn)與定點(diǎn)概述,很值得學(xué)習(xí)一下,需要的朋友可以參考一下。2016-06-06C++深入講解new與deleted關(guān)鍵字的使用
這篇文章主要介紹了C++中new與deleted關(guān)鍵字的使用,new在動態(tài)內(nèi)存中為對象分配空間并返回一個指向該對象的指針;delete接受一個動態(tài)對象的指針, 銷毀該對象, 并釋放與之關(guān)聯(lián)的內(nèi)存2022-05-05C語言模擬實現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言模擬實現(xiàn)學(xué)生學(xué)籍管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07C數(shù)據(jù)結(jié)構(gòu)之雙鏈表詳細(xì)示例分析
以下是對c語言中的雙鏈表進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-08-08C++實現(xiàn)LeetCode(103.二叉樹的之字形層序遍歷)
這篇文章主要介紹了C++實現(xiàn)LeetCode(103.二叉樹的之字形層序遍歷),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07c語言獲取當(dāng)前工作路徑的實現(xiàn)代碼(windows/linux)
這篇文章主要介紹了c語言獲取當(dāng)前工作路徑的實現(xiàn)代碼(windows/linux),需要的朋友可以參考下2017-09-09