這篇文章將為大家詳細講解有關C語言如何實現單鏈表,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:域名注冊、虛擬空間、營銷軟件、網站建設、竹溪網站維護、網站推廣。C語言實現單鏈表實現方法
鏈表和我們之前實現過的順序表一樣,都是簡單的數據結構,鏈表分為單向鏈表、雙向鏈表、循環鏈表。而單向鏈表又分為兩種實現方法,一種為帶頭節點的單鏈表,一種為不帶頭節點的單鏈表。我們來具體看看不帶頭節點的單鏈表的實現
單鏈表:它是一種鏈式存儲的線性表,用一組地址任意的存儲單元存放線性表的數據元素,稱存儲單元為一個節點。
今天我們來實現一些單鏈表的簡單接口
先看看單鏈表的結構: (為了通用性,我們將類型重命名為DataType)
typedef int DataType; //鏈表 typedef struct Node { DataType *data; struct Node *next; }Node, *pNode, *pList;
接下來看看我們要實現的接口:
void InitLinkList(pList *pplist);//初始化鏈表 pNode BuyNode(DataType d);//創建鏈表節點 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);//銷毀鏈表
來看看每個接口的具體實現:
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; //鏈表沒有節點 if (*pplist == NULL) { *pplist = newNode; return; } //鏈表有節點 while (cur->next != NULL) { cur = cur->next; } cur->next = newNode; } void PopBack(pList *pplist) { pNode cur = *pplist; pNode prev = NULL; assert(pplist); //鏈表沒有節點 if (*pplist == NULL) { return; } //鏈表有一個節點 if (cur->next == NULL) { free(*pplist); *pplist = NULL; return; } //鏈表有兩個及兩個以上節點 while (cur->next != NULL) { prev = cur;//prev中保存的是cur之前的那個節點 cur = cur->next; } prev->next = NULL; free(cur); } void PushFront(pList *pplist, DataType d) { pNode newNode = BuyNode(d); //pNode cur = *pplist; assert(pplist); ////鏈表沒有節點 //if (*pplist == NULL) //{ // *pplist = newNode; //} ////鏈表有節點 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); //要刪除的是尾節點 if (pos->next == NULL) { PopBack(pplist); } //刪除的是非尾節點 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; } }
由于這些接口都較為簡單,所以不進行具體的測試展示,讀者可以自行測試
關于“C語言如何實現單鏈表”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
另外有需要云服務器可以了解下創新互聯建站vcdvsql.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網頁名稱:C語言如何實現單鏈表-創新互聯
本文地址:http://vcdvsql.cn/article0/csepoo.html
成都網站建設公司_創新互聯,為您提供品牌網站設計、網站排名、外貿網站建設、響應式網站、商城網站、App開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯