單鏈表,咕咕咕

1.引入單鏈表

順序表對于中間或者頭部的刪除,時間復雜度為O(N),增容需要申請新的空間,拷貝數據,釋放就空間,消耗。增容一般是2倍的增長,會有空間的浪費。為了解決這些問題,引入了單鏈表。

2.單鏈表

鏈表是一種物理存儲結構上非連續的,非順序的存儲結構,邏輯結構上通過鏈表中指針鏈接實現連續性。類似火車頭,節。與順序表不同的是,鏈表的每一結點都是獨立申請的空間,結點一般包含當前結點要保存的數據與下一個結點的地址,一般是從堆上申請。

struct SListNode
{
int data;
struct SListNode* next;
};

這就是一個結點的結構體。

3.單鏈表的實現

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
typedef int sl;
typedef struct slist
{sl data;struct slist* next;
}listnode;
//申請一個節點
listnode* buylistnode(sl x)
{listnode* node=(listnode*)malloc(sizeof(listnode));if(node==NULL){perror("buylistnode");exit(-1);}node->next=NULL;node->data=x;return node;
}
//單鏈表打印
void listprint(listnode* p)
{while(p){printf("%d",p->data);p=p->next;}
}
//單鏈表尾插,為了改變真正的鏈表,要用二重指針。
//一重指針保存了數據的地址,我們要改變的是指針本身,不是它保存的地址,而是它本身的地址
void slpushback(listnode** pp,sl x)
{assert(pp);//頭結點本身的地址不能為空,但是頭結點保存的地址可以為空(起初鏈表為空)listnode* newnode=buylistnode(x);
//如果只有一個節點,那么直接在后面插入if(*pp==NULL){
*pp=newnode;}else{listnode* tail=*pp;while(tail->next){tail=tail->next;}tail->next=newnode;}
}
//單鏈表頭插
void slpushfront(listnode** pp,sl x)
{assert(pp);listnode* newnode=buylistnode(x);newnode->next=*pp;*pp=newnode;
}
//單鏈表尾刪
void slpopback(listnode** pp)
{assert(pp&&*pp);listnode* prev=NULL;listnode* tail=*pp;while(tail->next){
prev=tail;
tail=tail->next;}if(prev==NULL){*pp=NULL;}else{prev->next=NULL;}free(tail);
}
//單鏈表頭刪
void slpopfront(listnode** pp)
{assert(pp&&*pp);
//頭結點本身的地址不能為空,而且保存的地址也不能為空,不然
//(*pp)->next對空指針解引用就錯了listnode* next=(*pp)->next;free(*pp);*pp=next;
}
//單鏈表查找
listnode* slfind(listnode* p,sl x)
{while(p){if(p->data==x){return p;}p=p->next;}return NULL;
}
//單鏈表在pos之后插入
void slinsertafter(listnode* pos,sl x)
{assert(pos);listnode* newnode=buylistnode(x);newnode->next=pos->next;pos->next=newnode;
}
//刪除pos后的值
void sleraseafter(listnode* pos)
{assert(pos&&pos->next);listnode* n=pos->next;pos->next=n->next;free(n);
}
//pos之前插入
void slinsertfront(listnode** pp,listnode* pos,sl x)
{assert(pp);if(pos==NULL){slpushback(pp,x);return;}listnode* newnode=buylistnode(x);if(*pp==pos){newnode->next=*pp;*pp=newnode;}else{listnode* prev=*pp;while(prev!=NULL&&prev->next!=pos){prev=prev->next;}newnode->next=pos;prev->next=newnode;}
}
//刪除pos位置
void slerasepos(listnode** pp,listnode* pos)
{assert(pp&&pos);if(*pp==pos){*pp=pos->next;free(pos);}else{listnode* prev=*pp;while(prev!=NULL&&prev->next!=pos){prev=prev->next;}assert(prev!=NULL);prev->next=pos->next;free(pos);}
}
//刪除整個
void slerase(listnode**pp)
{assert(pp);listnode* p=NULL;while(*pp){p=*pp;*pp=(*pp)->next;free(p);}
}
int main()
{return 0;
}

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

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

相關文章

docker設置鏡像加速

配置鏡像加速器解決 Docker 拉取問題 在使用 Docker 拉取鏡像時&#xff0c;我首先按照官方指引嘗試配置阿里云鏡像加速器。然而&#xff0c;多次操作后仍無法正常使用&#xff0c;懷疑是個人賬號沒有權限拉取鏡像&#xff0c;但經過多輪權限檢查與配置核對&#xff0c;始終未…

【計算機網絡】王道考研筆記整理(2)物理層

第二章 物理層2.1 通信基礎的基本概念本節主要介紹通信中常用的一些基本概念&#xff0c;包括&#xff1a;信源、信宿、信號、信道&#xff0c;以及碼元、速率、波特。首先&#xff0c;我們來看什么是信源、信宿、信號、信道&#xff0c;這些概念通過一張圖就可以理解。其中&a…

2023年IEEE TITS SCI2區TOP,增強回溯搜索算法EBSA+多無人機輔助商業包裹遞送系統飛行規劃,深度解析+性能實測

目錄1.摘要2.回溯搜索算法BSA原理3.模型定義4.增強回溯搜索算法EBSA5.結果展示6.參考文獻7.算法輔導應用定制讀者交流1.摘要 利用無人機進行商業包裹投遞可以顯著推動物流行業的轉型升級&#xff0c;這得益于節省了人力資源成本&#xff0c;而無人機正在成為智能交通運輸系統的…

window wsl 環境下編譯openharmony,HarmonyOS 三方庫 FFmpeg

1.wsl 創建 C:\Users\Administrator>wsl --list --online 以下是可安裝的有效分發的列表。 使默認分發用 “*” 表示。 使用 wsl --install -d <Distro> 安裝。 NAME FRIENDLY NAME Ubuntu Ubuntu Debian Debian GNU/Linux kali-linux Kali Linux Rolling Ub…

Kubernetes服務暴露與負載均衡深度探析

目錄 Kubernetes服務基礎 服務類型與適用場景 服務發現與DNS 負載均衡機制 kube-proxy IPVS Ingress控制器 Ingress與服務暴露 Ingress資源 Ingress控制器 負載均衡策略與配置 服務配置 Ingress配置 IPVS配置 高可用性設計 服務冗余 Ingress控制器高可用 負載…

探索飛算 JavaAI 進階:解鎖高效Java開發的新維度

前引&#xff1a;在當今快速迭代的軟件開發領域&#xff0c;Java作為企業級應用的基石&#xff0c;持續推動著技術創新。隨著性能需求的提升&#xff0c;“飛算JAVA”應運而生&#xff0c;它融合了現代優化理念&#xff0c;為開發者提供了一套簡潔、高效的解決方案。本文將深入…

Java大廠面試故事:謝飛機的互聯網醫療系統技術面試(Spring Boot、MyBatis、Kafka、Spring Security、AI等)

Java大廠面試故事&#xff1a;謝飛機的互聯網醫療系統技術面試&#xff08;Spring Boot、MyBatis、Kafka、Spring Security、AI等&#xff09;本文以互聯網醫療場景為主線&#xff0c;模擬Java大廠真實面試流程&#xff0c;由嚴肅面試官與"水貨"程序員謝飛機展開有趣…

Deekseek 學習筆記

目錄 比較全的微調筆記&#xff0c;推薦&#xff1a; ds 硬件gpu測試網站&#xff1a; 比較全的微調筆記&#xff0c;推薦&#xff1a; 零基礎入門&#xff1a;DeepSeek微調教程來了&#xff01;_deepseek微調訓練-CSDN博客 r1微調筆記&#xff1a; https://zhuanlan.zhihu…

aksk前端簽名實現

需求&#xff1a; 頁面和后臺使用aksk進行簽名校驗&#xff0c;普通JSON參數簽名沒問題&#xff0c;但使用formData上傳文件時簽名總是無法通過后臺校驗 關鍵點&#xff1a; 1、瀏覽器在傳遞formData格式數據時會自動隨機boundary&#xff0c;這樣頁面無法在請求發起前拿到隨機…

基于物聯網的智能體重秤設計與實現

標題:基于物聯網的智能體重秤設計與實現內容:1.摘要 隨著物聯網技術的飛速發展&#xff0c;智能設備在人們日常生活中的應用越來越廣泛。本研究的目的是設計并實現一款基于物聯網的智能體重秤&#xff0c;以滿足人們對健康數據實時監測和管理的需求。方法上&#xff0c;采用高精…

安全領域的 AI 采用:主要用例和需避免的錯誤

作者&#xff1a;來自 Elastic Elastic Security Team 安全領域的 AI 采用&#xff1a;主要用例和需避免的錯誤 人工智能&#xff08;artificial intelligence - AI&#xff09;在安全領域的廣泛應用呈現出一種矛盾。一方面&#xff0c;它幫助安全專家大規模應對高級威脅&…

Element-Plus-全局自動引入圖標組件,無需每次import

效果圖配置如下1、核心代碼修改main.js/ts//main.js // 全局注冊圖標組件 import * as ElementPlusIconsVue from element-plus/icons-vue for (const [key, component] of Object.entries(ElementPlusIconsVue)) {app.component(key, component) } app.use(ElementPlusIconsVu…

日歷插件-FullCalendar的詳細使用

一、介紹FullCalendar 是一個功能強大、高度可定制的 JavaScript 日歷組件&#xff0c;用于在網頁中顯示和管理日歷事件。它支持多種視圖&#xff08;月、周、日等&#xff09;&#xff0c;可以輕松集成各種框架&#xff0c;并提供豐富的事件處理功能。二、實操案例具體代碼如下…

【A題解題思路】2025APMCM亞太杯中文賽A題解題思路+可運行代碼參考(無償分享)

注&#xff1a;該內容由“數模加油站”原創&#xff0c;無償分享&#xff0c;可以領取參考但不要利用該內容倒賣&#xff0c;謝謝&#xff01;A 題 農業灌溉系統優化問題1思路框架&#xff1a;1.1 研究背景與問題意義土壤濕度是農業生產中影響作物根系水分供應的關鍵環境指標。…

【JAVA】面向對象三大特性之繼承

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄前言一、繼承的概念和使用細則1.1 繼承的基本使用和含義1.2 關于子類訪問父類成員的問題1.3 super關鍵的引出1.4 super調用父類當中指定的構造方法1.5 關于super和th…

基于深度學習的自動調制識別網絡(持續更新)

基于卷積神經網絡架構 CNN 參考文獻 T.J. O’Shea, J. Corgan, T.C. Clancy, Convolutional radio modulation recognition networks, in: Proc. Int. Conf. Eng. Appl. Neural Netw., Springer, 2016, pp. 213–226. MCNet 參考文獻 T. Huynh-The, C.-H. Hua, Q.-V. Pha…

Java進階---并發編程

一.線程復習1.什么是線程&#xff0c;進程進程是操作系統分配資源的基本單位線程是進程中的一個執行單元(一個獨立執行的任務)&#xff0c;是cpu執行的最小單元2.Java中如何創建線程1.繼承Thread類&#xff0c;重寫run()&#xff0c;直接創建子類的對象2.類實現Runnable接口&am…

小車循跡功能的實現(第六天)

&#x1f468;?&#x1f4bb;個人主頁&#xff1a;開發者-削好皮的Pineapple! &#x1f468;?&#x1f4bb; hello 歡迎 點贊&#x1f44d; 收藏? 留言&#x1f4dd; 加關注?! &#x1f468;?&#x1f4bb; 本文由 削好皮的Pineapple! 原創 &#x1f468;?&#x1f4…

C++ auto與 for循環

一、數組 #include <iostream> #include <vector> using namespace std; int main() {int vec[6] {1,2,3};for (auto num : vec) { /* num 是 int */ cout << "Hello, world!" << num <<endl;}return 0; }二、STL容器與迭代器 for 循…

【RK3568+PG2L50H開發板實驗例程】FPGA部分 | ROM、RAM、FIFO 的使用

本原創文章由深圳市小眼睛科技有限公司創作&#xff0c;版權歸本公司所有&#xff0c;如需轉載&#xff0c;需授權并注明出處&#xff08;www.meyesemi.com) 1.實驗簡介 實驗目的&#xff1a; 掌握紫光平臺的 RAM、ROM、FIFO IP 的使用 實驗環境&#xff1a; Window11 PDS2022…