C語(yǔ)言實(shí)現(xiàn)單鏈表實(shí)現(xiàn)方法
C語(yǔ)言實(shí)現(xiàn)單鏈表實(shí)現(xiàn)方法
鏈表和我們之前實(shí)現(xiàn)過(guò)的順序表一樣,都是簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu),鏈表分為單向鏈表、雙向鏈表、循環(huán)鏈表。而單向鏈表又分為兩種實(shí)現(xiàn)方法,一種為帶頭節(jié)點(diǎn)的單鏈表,一種為不帶頭節(jié)點(diǎn)的單鏈表。我們來(lái)具體看看不帶頭節(jié)點(diǎn)的單鏈表的實(shí)現(xiàn)
單鏈表:它是一種鏈?zhǔn)酱鎯?chǔ)的線性表,用一組地址任意的存儲(chǔ)單元存放線性表的數(shù)據(jù)元素,稱存儲(chǔ)單元為一個(gè)節(jié)點(diǎn)。

今天我們來(lái)實(shí)現(xiàn)一些單鏈表的簡(jiǎn)單接口
先看看單鏈表的結(jié)構(gòu): (為了通用性,我們將類型重命名為DataType)
typedef int DataType;
//鏈表
typedef struct Node
{
DataType *data;
struct Node *next;
}Node, *pNode, *pList;
接下來(lái)看看我們要實(shí)現(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);//刪除指定的一個(gè)元素 void RemoveAll(pList *pplist, DataType d);//刪除指定的所有元素 void Insert(pList *pplist, pNode pos, DataType d);//指定位置的后面插入 void Erase(pList *pplist, pNode pos);//指定位置刪除 void DestroyList(pList *pplist);//銷毀鏈表
來(lái)看看每個(gè)接口的具體實(shí)現(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;
//鏈表沒(méi)有節(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);
//鏈表沒(méi)有節(jié)點(diǎn)
if (*pplist == NULL)
{
return;
}
//鏈表有一個(gè)節(jié)點(diǎn)
if (cur->next == NULL)
{
free(*pplist);
*pplist = NULL;
return;
}
//鏈表有兩個(gè)及兩個(gè)以上節(jié)點(diǎn)
while (cur->next != NULL)
{
prev = cur;//prev中保存的是cur之前的那個(gè)節(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);
////鏈表沒(méi)有節(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后面插入一個(gè)元素
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ǎng)h除的是尾節(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;
}
}
由于這些接口都較為簡(jiǎn)單,所以不進(jìn)行具體的測(cè)試展示,讀者可以自行測(cè)試
以上就是C語(yǔ)言實(shí)現(xiàn)單鏈表實(shí)現(xiàn)方法,如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- C語(yǔ)言之單鏈表的插入、刪除與查找
- C語(yǔ)言實(shí)現(xiàn)單鏈表逆序與逆序輸出實(shí)例
- C語(yǔ)言單鏈表常見(jiàn)操作匯總
- c語(yǔ)言實(shí)現(xiàn)單鏈表算法示例分享
- C語(yǔ)言單鏈表實(shí)現(xiàn)多項(xiàng)式相加
- C語(yǔ)言單鏈表的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu) C語(yǔ)言實(shí)現(xiàn)循環(huán)單鏈表的實(shí)例
- C語(yǔ)言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(單鏈表)
- C語(yǔ)言單鏈表版學(xué)生信息管理系統(tǒng)
- C語(yǔ)言單鏈表實(shí)現(xiàn)方法詳解
相關(guān)文章
DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)與定點(diǎn)概述
本文主要介紹DSP中浮點(diǎn)與定點(diǎn)概述,很值得學(xué)習(xí)一下,需要的朋友可以參考一下。2016-06-06
C++深入講解new與deleted關(guān)鍵字的使用
這篇文章主要介紹了C++中new與deleted關(guān)鍵字的使用,new在動(dòng)態(tài)內(nèi)存中為對(duì)象分配空間并返回一個(gè)指向該對(duì)象的指針;delete接受一個(gè)動(dòng)態(tài)對(duì)象的指針, 銷毀該對(duì)象, 并釋放與之關(guān)聯(lián)的內(nèi)存2022-05-05
C語(yǔ)言模擬實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言模擬實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
C數(shù)據(jù)結(jié)構(gòu)之雙鏈表詳細(xì)示例分析
以下是對(duì)c語(yǔ)言中的雙鏈表進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08
C++實(shí)現(xiàn)LeetCode(103.二叉樹的之字形層序遍歷)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(103.二叉樹的之字形層序遍歷),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
c語(yǔ)言獲取當(dāng)前工作路徑的實(shí)現(xiàn)代碼(windows/linux)
這篇文章主要介紹了c語(yǔ)言獲取當(dāng)前工作路徑的實(shí)現(xiàn)代碼(windows/linux),需要的朋友可以參考下2017-09-09

