C語言如何創建?個動態鏈表?

一、問題

????????創建動態鏈表就是指在程序執?過程中,從?到有,按照需求開辟結點和輸?各結點數據,并建?起前后相連接的關系。那么,如何創建動態鏈表呢?

二、解答

????????以建??個有任意名學?數據的單向動態鏈表為例,可以根據需要,動態地為學?分配內存,直到輸?學號為 0 ,則結束輸?,不再創建,然后將動態創建的學?信息輸出。 創建?個動態鏈表函數的相應代碼如下。

stu *creat(void)
{stu *head, *p1, *p2;n = 0;p1 = p2 = (stu *)malloc(LEN);scanf("%d,%d,%f", &p1->num, &p1->age, &p1->score);head = NULL;while (p1->num != 0){n = n + 1;if (n == 1){head = p1;}else{p2->next = p1;}p2 = p1;p1 = (stu *)malloc(LEN);scanf("%d,%d,%f", &p1->num, &p1->age, &p1->score);}p2->next = NULL;return head;
}

????????在創建函數中,若輸?學號為 0 ,則說明鏈表建?完成。建?鏈表之前,?先使 head 指向?個空指針,表?此時的鏈表?結點,當建?了第?個結點后,就令 head 指向該結點。

????????實現創建鏈表的過程如下:

(1)在為 p1 和 p2 開辟了內存空間后,從鍵盤輸??個學?的數據信息給 p1 所指的第?個結點。若學號不為0,則這輸?的是第?個數據,即 n=1,那么令 head 指向該結點, 即 head=p1,把 p1 的值賦給 head,如圖所示。

(2)建?完第?個結點后,再開辟?個結點并使 p1指向該結點。向結點中輸?數據, 如果第?個結點的學號不為 0 ,此時 n=2,則第?個結點就是第?個結點的直接后繼。使 p2 的指針域指向第?個結點,建?聯系,此時鏈表的形式如圖所示。

(3)第?個結點建?后,使 p2 指向新建?的第?個結點,?便 pl 再去開辟新的內存,建?下?個結點。建?下?個結點的?法同(2),第三個結點的建?如下圖所示。

(4)下?個結點的建??法同(2),直到鍵盤輸?學號為 0,則鏈表建?結束,學號為 0 這個結點不連接到鏈表中。

????????創建動態鏈表結束后,就可以在主函數中調?創建函數。該創建函數?傳遞參數,返回值為頭指針。創建鏈表結束后,輸出學?數據,運?結果如圖所示。

101,18,90,0
102,20,89,3
103,19,88,3
0
101,18,90.000000
102,20,89,300003
103,19,88.300003

三、總結

????????在創建動態鏈表的函數中,需要注意在開辟完?個結點后,需要先向結點中輸?數據, 再將前?個結點與后?個結點建?聯系,即前?個結點的指針域指向后?個結點,這樣才能將開辟的結點建?鏈式結構。

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

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

相關文章

使用mysql主從熱備+keepalived服務+ipvsadm工具 實現 mysql高可用主備+負載均衡

目錄 1、工作原理 2、環境準備 3、分別在主服務器和備用服務器上安裝keepalived和ipvsadm 4、修改keepalived服務的配置文件 4.1 修改主服務器上的keepalive服務的配置文件 4.2 修改備用服務器上的keepalive服務配置文件 5、編寫mysql監控腳本放到主服務器上 6、在主服…

echers配置項:X軸,Y軸顏色修改

如上圖綠框所示,修改x,y軸的顏色 let option {xAxis: {axisLine:{lineStyle:{color:red}},},yAxis: {type: value,axisLine:{lineStyle:{color:red}},}, }

學習MySQL(六):Python的連接與操作

安裝第三方模塊pymysql pip install pymysql 或者 通過PyCharm后臺操作 連接mysql # 語法示例 import pymysql db pymysql.connect(hostlocalhost,userroot,password"123456",databaseschool,port3306,charset"utf8") 數據操作的基本語法 import pymys…

通過gen_compile_commands.py產生compile_commands.json文件的方法

大家在使用vscode查看linux源代碼時,會有很多飄紅處,而且函數的跳轉非常不方便。所以linux給了一個腳本gen_compile_commands.py,此腳本類似ctags這樣,產生相應的關聯之類的數據庫,方便函數及文件的跳轉等等。非常好。…

軟件測試委托合同(Word原件實際參考)

一、 任務表述 二、雙方的主要義務 三、履約地點 四、合同價款 五、測試費用支付方式 六、履行的期限 七、資料的保密 八、 風險責任的承擔 九、驗收方法 十、 爭議解決 十一、 其他 十二、簽章 十三、計算機軟件產品鑒定測試保密協議 軟件資料清單列表部分文檔: …

Object.wait()和LockSupport.park()

Object.wait() 和 LockSupport.park() 都是用來使當前線程等待的方法,但它們在使用場景和機制上有所不同: Object.wait() 用途:wait() 方法屬于對象監視器(Monitor)的一部分,通常與 synchronized 塊或方法…

電感式傳感器

電感傳感器是基于電磁感應原理,將被測非電量(如位移、壓力、振動等)轉換為電感量變化的一種結構性傳感器。利用自感原理的有自感式傳感器(可變磁阻式),利用互感原理的有互感式(差動變壓器式和渦…

AI學習指南線性代數篇-矩陣的運算

AI學習指南線性代數篇-矩陣的運算 線性代數中,矩陣的運算是一項重要而基礎的內容。在人工智能領域,矩陣的運算被廣泛應用于各種算法中,如神經網絡、圖像處理、自然語言處理等。本文將從矩陣的運算概述、在AI中的使用場景、定義和意義以及公式…

QT:QML制作線形圖

目錄 一.介紹 二.引入庫 三.自定義屬性 四.懸停處理函數 五.設置X軸 六.設置Y軸 七.畫線 八.測試點坐標 九.設置值 十.效果演示 十一.代碼演示 1.LineGraph.qml 2.main.qml 一.介紹 線形圖(也稱為折線圖)是一種常用的數據可視化工具&#…

如何找到MySQL中存儲引擎所對應的表空間并且打開?

在上節課我們學習了數據庫(MySQL)進階:存儲引擎,有不少同學產生疑惑,到底要怎么找到表空間并且打開啊?這節課我們就來探討。 首先,根據這個路徑:C:\ProgramData\MySQL\MySQL Server…

mybatis-plus如何使用QueryWrapper和LambdaQueryWrapper的and方法?

構造器去構造條件的時候,我們都知道eq方法去鏈式的時候是自動添加and的,那如果需要and的那個條件需要加括號呢? 環境 Jdk 1.8、mybatis-plus 3.5.3.2、mysql 5.7.11 示例 sql: select * from user where openid 1 and (phon…

谷歌Flank潛藏3年的Github Action供應鏈攻擊

01 簡 介 Flank [1] 是谷歌 Firebase Test lab 開源在 Github 的一個項目,用于同時對多個安卓和IOS設備進行測試。2024年4月15號 AWS 安全工程師 Adnan Khan 公布了關于該項目代碼倉庫 Github Action CI/CD 存在漏洞的細節[2],漏洞在2020年于此 代碼合…

通信網絡時鐘同步(PTP網絡授時服務器)技術探討

通信網絡時鐘同步(NTP網絡授時服務器)技術探討 通信網絡時鐘同步(NTP網絡授時服務器)技術探討 1、著移動通信業務的發展和移動用戶的快速增長, 移動網絡架構向IP化、寬帶化進展。為了適應業務IP化發展趨勢&#xff0c…

02 VUE學習:模板語法

模板語法 Vue 使用一種基于 HTML 的模板語法,使我們能夠聲明式地將其組件實例的數據綁定到呈現的 DOM 上。所有的 Vue 模板都是語法層面合法的 HTML,可以被符合規范的瀏覽器和 HTML 解析器解析。 在底層機制中,Vue 會將模板編譯成高度優化的…

開發vue3,真的可以不用ref/reactive了,也不需要ref.value

什么是Cabloy-Front? Cabloy-Front 是一款支持 IOC 容器的 Vue3 框架。不用ref/reactive,不用ref.value,不用pinia 與UI庫的配合 Cabloy-Front 可以搭配任何 UI 庫使用,并且內置了幾款 UI 庫的項目模版,便于開箱即用…

免費SSL證書簽發安裝指南

一、簽發 1.選擇證書頒發機構(CA):首先,你需要找到一個提供免費SSL證書的CA。有些CA會提供永久免費的SSL證書,而有些則可能只提供有限時間的試用證書,如JoySSL就提供永久免費證書。 2.生成CSR&#xff08…

WPF 鼠標拖拽平移

效果 xaml <ScrollViewer x:Name"scrollViewer" HorizontalScrollBarVisibility"Hidden" VerticalScrollBarVisibility"Disabled" Background"#FFF1ADAD"PreviewMouseDown"ScrollViewer_OnPreviewMouseDown"PreviewMou…

Electron學習筆記(一)

文章目錄 相關筆記筆記說明 一、輕松入門 1、搭建開發環境2、創建窗口界面3、調試主進程 二、主進程和渲染進程1、進程互訪2、渲染進程訪問主進程類型3、渲染進程訪問主進程自定義內容4、渲染進程向主進程發送消息5、主進程向渲染進程發送消息6、多個窗口的渲染進程接收主進程發…

白鯨開源CEO郭煒在2024 DataOps發展大會上獲聘專家

2024年5月15日&#xff0c;白鯨開源CEO郭煒在2024 DataOps發展大會上被正式聘任為DataOps專家&#xff0c;并獲得了榮譽證書。本次大會由中國通信標準化協會主辦&#xff0c;中關村科學城管委會提供支持&#xff0c;大數據技術標準推進委員會&#xff08;CCSATC601&#xff09;…

iisnginx環境一次奇怪的跨域問題解決經過

跨域問題描述&#xff1a; iis網站跨域、nginx 網站跨域 都已配置&#xff0c;訪問接口依然出現跨域問題。 錯誤提示&#xff1a; ccess to XMLHttpRequest at ‘https://xxx.com/gameapi/preserve/get/status’ from origin ‘https://cdn.xxx.com’ has been blocked by CO…