C語言中單鏈表操作:查找節點與刪除節點

一. 簡介

前面學習了C語言中創建鏈表節點,向鏈表中插入節點等操作,文章如下:

C語言中單向鏈表:創建節點與插入新節點-CSDN博客

本文繼續學習c語言中對鏈表的其他操作,例如在鏈表中查找某個節點,刪除鏈表中某個節點,遍歷鏈表,釋放鏈表等等操作。

二. C語言中單鏈表操作:查找節點與刪除節點

1. 遍歷鏈表

遍歷鏈表就是依次訪問鏈表中的每個節點,打印或者處理每個節點中的數據,下面示例遍歷鏈表并輸出每個節點中的數據:

//遍歷鏈表
void traverse_list(Node* head) {Node* current = head;while(current != NULL) {printf("%d\n", current->data);current = current->next;}
}

1. 查找節點

查找節點具體就是在鏈表中查找指定值的節點。

//查找鏈表中指定數據所在的節點
Node* search_list_node(Node* head, int data) {Node* current = head;if(current == NULL) {return NULL;}while(current != NULL) {if(current->data == data) {return current;}current = current->next;}    return NULL;
}

2. 刪除鏈表中的某個節點

刪除節點可以刪除頭部節點、尾部節點或者指定位置的節點。

(1) 刪除鏈表的頭部節點

刪除鏈表中的頭部節點,只需要將頭指針指向下一個節點,釋放第一個節點即可:

//刪除鏈表中的頭部節點
Node* delete_at_list_head(Node* head) {if(head == NULL) {return NULL;}//保存當前頭節點Node* tmp_p = head;//移動頭指針到下一個節點head = head->next; //釋放原來的頭節點free(tmp_p);return head;
}

(2) 刪除鏈表的尾部節點

刪除鏈表的尾部節點時,需要遍歷整個鏈表找到尾節點的前一個節點,將該節點的 next 置為 NULL,并釋放掉尾節點。示例如下:

//刪除鏈表中的尾部節點
Node* delete_at_list_tail(Node* head) {//如果鏈表為空if(head == NULL) {return NULL;}//如果鏈表只有一個節點if(head->next == NULL) {free(head);return NULL;}//查找鏈表尾節點的前一個節點(即倒數第二個節點)Node* tmp_p = head;while(tmp_p->next->next != NULL) {tmp_p = tmp_p->next;}//釋放鏈表中最后一個節點free(tmp_p->next);//將倒數第二個節點的 next指針指向NULLtmp_p->next = NULL;return head;
}

(3) 刪除鏈表中指定位置的節點

刪除鏈表中指定位置節點時,首先需要遍歷鏈表,找到目標節點的前一個節點,然后調節其 next指針跳過目標節點。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/76403.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/76403.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/76403.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

WePY 框架:小程序開發的“Vue式”利器!!!

WePY 框架:小程序開發的“Vue式”利器 🚀 哈嘍,大家好!👋 今天我們要聊聊一個在微信小程序開發中大放異彩的框架——WePY!它是什么?有什么特點?為啥值得一試?別急&#…

什么是微前端?有什么好處?有哪一些方案?

微前端(Micro Frontends) 微前端是一種架構理念,借鑒了微服務的思想,將一個大型的前端應用拆分為多個獨立、自治的子應用,每個子應用可以由不同團隊、使用不同技術棧獨立開發和部署,最終聚合為一個整體產品…

【家政平臺開發(33)】庫存管理模塊開發實戰:從基礎搭建到智能管控

本【家政平臺開發】專欄聚焦家政平臺從 0 到 1 的全流程打造。從前期需求分析,剖析家政行業現狀、挖掘用戶需求與梳理功能要點,到系統設計階段的架構選型、數據庫構建,再到開發階段各模塊逐一實現。涵蓋移動與 PC 端設計、接口開發及性能優化,測試階段多維度保障平臺質量,…

Mysql個人筆記

Mysql個人筆記 sql基礎書寫規則和種類種類書寫規則注釋規則啟動 DDL數據類型數據庫的操作useshowcreatedrop 表的操作useshowcreate創建表復制表 dropalter Mysql的存儲引擎 DMLselectselect語句like(謂詞)where聚合函數:關于nullgroup byexi…

【重裝系統】大白菜自制U盤裝機,備份C盤數據,解決電腦啟動黑屏/藍屏

1. 準備 U 盤 U 盤容量至少 8G,備份 U 盤的數據(后期會格式化) 2. 從微軟官網下載操作系統鏡像 https://www.microsoft.com/zh-cn/software-download/windows11 3. 下載安裝大白菜 https://www.alipan.com/s/33RVnKayUfY 4. 插入 U 盤&#…

各類神經網絡學習:(十)注意力機制(第2/4集),pytorch 中的多維注意力機制、自注意力機制、掩碼自注意力機制、多頭注意力機制

上一篇下一篇注意力機制(第1/4集)待編寫 一、pytorch 中的多維注意力機制: 在 N L P NLP NLP 領域內,上述三個參數都是 向量 , 在 p y t o r c h pytorch pytorch 中參數向量會組成 矩陣 ,方便代碼編寫。…

uni-app初學

文章目錄 1. pages.json 頁面路由2. 圖標3. 全局 CSS4. 首頁4.1 整體框架4.2 完整代碼4.3 輪播圖 swiper4.3.1 image 4.4 公告4.4.1 uni-icons 4.5 分類 uni-row、uni-col4.6 商品列表 小程序開發網址: 注冊小程序賬號 微信開發者工具下載 uniapp 官網 HbuilderX 下…

VBA將Word文檔內容逐行寫入Excel

如果你需要將Word文檔的內容導入Excel工作表來進行數據加工,使用下面的代碼可以實現: Sub ImportWordToExcel()Dim wordApp As Word.ApplicationDim wordDoc As Word.DocumentDim excelSheet As WorksheetDim filePath As VariantDim i As LongDim para…

MySQL運行一段時間后磁盤出現100%讀寫

MySQL運行一段時間后磁盤出現100%讀寫的情況,可能是由多種原因導致的,以下是一些常見原因及解決方法: 可能的原因 1. 磁盤I/O壓力過大[^0^]:數據量過大,數據庫查詢和寫入操作消耗大量I/O資源。索引效率低&#xff0c…

【RabbitMQ】延遲隊列

1.概述 延遲隊列其實就是隊列里的消息是希望在指定時間到了以后或之前取出和處理,簡單來說,延時隊列就是用來存放需要在指定時間被處理的元素的隊列。 延時隊列的使用場景: 1.訂單在十分鐘之內未支付則自動取消 2.新創建的店鋪,…

Linux筆記之Ubuntu系統設置自動登錄tty1界面

Ubuntu22.04系統 編輯getty配置文件 vim /etc/systemd/system/gettytty1.service.d/override.conf如果該目錄或者文件不存在,進行創建。 在override.conf文件中進行編輯: [Service] ExecStart ExecStart-/sbin/agetty --autologin yourusername --no…

C++程序詩篇的靈動賦形:多態

文章目錄 1.什么是多態?2.多態的語法實現2.1 虛函數2.2 多態的構成2.3 虛函數的重寫2.3.1 協變2.3.2 析構函數的重寫 2.4 override 和 final 3.抽象類4.多態原理4.1 虛函數表4.2 多態原理實現4.3 動態綁定與靜態綁定 5.繼承和多態常見的面試問題希望讀者們多多三連支…

算法訓練之動態規劃(三)

???~~~~~~歡迎光臨知星小度博客空間~~~~~~??? ???零星地變得優秀~也能拼湊出星河~??? ???我們一起努力成為更好的自己~??? ???如果這一篇博客對你有幫助~別忘了點贊分享哦~??? ???如果有什么問題可以評論區留言或者私信我哦~??? ?????? 個…

$_GET變量

$_GET 是一個超級全局變量,在 PHP 中用于收集通過 URL 查詢字符串傳遞的參數。它是一個關聯數組,包含了所有通過 HTTP GET 方法發送到當前腳本的變量。 預定義的 $_GET 變量用于收集來自 method"get" 的表單中的值。 從帶有 GET 方法的表單發…

jQuery多庫共存

在現代Web開發中,項目往往需要集成多種JavaScript庫或框架來滿足不同的功能需求。然而,當多個庫同時使用時,可能會出現命名沖突、功能覆蓋等問題。幸運的是,jQuery提供了一些機制來確保其可以與其他庫和諧共存。本文將探討如何實現…

MySQL 中的聚簇索引和非聚簇索引有什么區別?

MySQL 中的聚簇索引和非聚簇索引有什么區別? 1. 從不同存儲引擎去考慮 在MySIAM存儲引擎中,索引和數據是分開存儲的,包括主鍵索引在內的所有索引都是“非聚簇”的,每個索引的葉子節點存儲的是數據記錄的物理地址(指針…

Java從入門到“放棄”(精通)之旅——啟航①

🌟Java從入門到“放棄 ”精通之旅🚀 今天我將要帶大家一起探索神奇的Java世界!希望能幫助到同樣初學Java的你~ (??????)?? 🔥 Java是什么?為什么這么火? Java不僅僅是一門編程語言,更…

三相電為什么沒零線也能通電

要理解三相電為什么沒零線也能通電,就要從發電的原理說起 1、弧形磁鐵中加入電樞,旋轉切割磁感線會產生電流 隨著電樞旋轉的角度變化,電樞垂直切割磁感線 電樞垂直切割磁感線,此時會產生最大電壓 當轉到與磁感線平行時&#xf…

文件上傳做題記錄

1,[SWPUCTF 2021 新生賽]easyupload2.0 直接上傳php 再試一下phtml 用蟻劍連發現連不上 那就只要命令執行了 2,[SWPUCTF 2021 新生賽]easyupload1.0 當然,直接上傳一個php是不行的 phtml也不行,看下是不是前端驗證,…

【Pandas】pandas DataFrame head

Pandas2.2 DataFrame Indexing, iteration 方法描述DataFrame.head([n])用于返回 DataFrame 的前幾行 pandas.DataFrame.head pandas.DataFrame.head 是一個方法,用于返回 DataFrame 的前幾行。這個方法非常有用,特別是在需要快速查看 DataFrame 的前…