c語言實現鏈表

鏈表是一種常見的數據結構,用于存儲一系列的元素。它由一系列的節點(Node)組成,每個節點包含數據和指向下一個節點的指針。不同于數組需要連續的內存空間來存儲元素,鏈表使用指針將節點按照某種邏輯順序連接起來。

每個節點通常由兩個部分組成:數據部分(存儲元素的值)和指針部分(指向下一個節點)。鏈表的開頭節點稱為頭節點(Head),而最后一個節點沒有指針指向下一個節點的位置,通常使用空指針(NULL)來表示鏈表的結尾。

#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include<stdlib.h>
#include<stdio.h>#ifdef __cplusplus
extern "C" {
#endifstruct LinkNode {int num;struct LinkNode* next;};struct LinkNode* Init_LinkList();void foreach_LinkList(struct LinkNode* pHeader);void insert_LinkList(struct LinkNode* pHeader, int oldval, int newval);void delete_LinkList(struct LinkNode* pHeader, int delval);void clear_LinkList(struct LinkNode* pHeader);void destroy_LinkList(struct  LinkNode* pHeader);void rever_LinkList(struct LinkNode* pHeader);int size_LinkList(struct LinkNode* pHeader);
#ifdef __cplusplus
}
#endif

?

#include"LinkList.h"
struct LinkNode* Init_LinkList()
{struct LinkNode* pHeader = malloc(sizeof(struct LinkNode));if (pHeader == NULL){return ;}pHeader->num = -1; pHeader->next = NULL;int val = -1;struct LinkNode* pTail = pHeader;while (1){printf("請插入數據,輸入-1結束\n");scanf_s("%d",&val);if (val == -1){break;}//創建新節點struct LinkNode* newNode = malloc(sizeof(struct LinkNode));newNode->num = val;newNode->next = NULL;pTail->next = newNode;//連接pTail = newNode;}return pHeader;
}
void foreach_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){printf("%d\n", pCurrent->num);pCurrent = pCurrent->next;}
}
void insert_LinkList(struct LinkNode* pHeader, int oldval, int newval)
{struct LinkNode* pPrev = pHeader;struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){if (pCurrent->num == oldval){break;}pPrev = pCurrent;pCurrent = pCurrent->next;}struct LinkNode* newNode = malloc(sizeof(struct LinkNode));newNode->num = newval;newNode->next = NULL;newNode->next = pCurrent;pPrev->next = newNode;
}void delete_LinkList(struct LinkNode* pHeader, int deval)
{if (pHeader == NULL){return;}struct LinkNode* pPrev = pHeader;struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){if(pCurrent->num==deval){break;}pPrev->next = pCurrent;pCurrent = pCurrent->next;}if (pCurrent == NULL){return;}pPrev->next = pCurrent->next;free(pCurrent);pCurrent = NULL;
}
void clear_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pCurrent = pHeader->next;while (pCurrent != NULL){struct LinkNode* nextnode = pCurrent->next;free(pCurrent);pCurrent = nextnode;}pHeader->next = NULL;
}
void destroy_LinkList(struct  LinkNode* pHeader)
{if (pHeader == NULL){return;}clear_LinkList(pHeader);free(pHeader);pHeader = NULL;}
void rever_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pPrev;struct LinkNode* pCurrent;struct LinkNode* pNext;pPrev = NULL;pNext= NULL;pCurrent = pHeader->next;while (pCurrent != NULL){pNext = pCurrent->next;pCurrent->next = pPrev;pPrev = pCurrent;pCurrent = pNext;}pHeader->next = pPrev;
}
int size_LinkList(struct LinkNode* pHeader)
{if (pHeader == NULL){return;}struct LinkNode* pCurrent = pHeader->next;int num = 0;while (pCurrent != NULL){num++;pCurrent = pCurrent->next;}return num;
}

?

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

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

相關文章

C 語言入門:如何編寫 Hello World

C 語言簡介 C 語言是由 Dennis Ritchie 于 1972 年在貝爾實驗室創建的一種通用編程語言。盡管年代久遠&#xff0c;它仍然是一款非常流行的語言。它之所以受歡迎的主要原因是它是計算機科學領域的基礎語言之一。C 語言與 UNIX 緊密相連&#xff0c;因為它被用于編寫 UNIX 操作…

Audio Signal (MATLAB) 代碼學習1-常見問題

問題描述 使用MATLAB完成如下操作 加載音頻文件,并存儲到變量x中將x和一個頻率為440Hz的正弦信號相加,用結果定義一個新的信號y繪制y信號的時域圖,并正確定義時間軸利用Hann window(漢寧窗)從y中提取一個20ms的窗信號利用線性預測編碼(階數20)預測白化濾波器的參數。% …

訊飛星火認知大模型與軟件測試結合,提升軟件質量與效率

隨著人工智能技術的不斷發展&#xff0c;越來越多的企業開始將其應用于軟件開發過程中。其中&#xff0c;訊飛星火認知大模型作為一種基于深度學習的自然語言處理技術&#xff0c;已經在語音識別、機器翻譯、智能問答等領域取得了顯著的成果。而在軟件測試領域&#xff0c;訊飛…

設置bat工作目錄

在執行bat腳本的時候&#xff0c;如果直接雙擊bat腳本&#xff0c;此時的工作路徑一般為C:\Users\Administrator> 很多時候需要將工作路徑設置為bat腳本所在的目錄&#xff0c;可以在bat腳本內設置當前工作路徑為bat文件所在目錄&#xff0c; cd /d %~dp0cd:設置工作目錄為…

【算法優選】 動態規劃之路徑問題——貳

文章目錄 &#x1f38b;前言&#x1f332;[下降最小路徑和](https://leetcode.cn/problems/minimum-path-sum/)&#x1f6a9;題目描述&#x1f6a9;算法思路&#xff1a;&#x1f6a9;代碼實現 &#x1f38d;[最小路徑和](https://leetcode.cn/problems/minimum-path-sum/)&…

viple與物理機器人(一):線控模擬

為了檢測viple程序與物理機器人是否能順利連接上 如果能順利連接上&#xff0c;那么&#xff0c;可以通過內建事件從而控制物理機器人的前進、后退、左轉、右轉以及暫停。 如果不能連接上&#xff0c;首先&#xff0c;程序無法控制物理機器人&#xff0c;其次&#xff0c;當vip…

公交站間的距離

&#x1f388; 算法并不一定都是很難的題目&#xff0c;也有很多只是一些代碼技巧&#xff0c;多進行一些算法題目的練習&#xff0c;可以幫助我們開闊解題思路&#xff0c;提升我們的邏輯思維能力&#xff0c;也可以將一些算法思維結合到業務代碼的編寫思考中。簡而言之&#…

我的 CSDN 三周年創作紀念日:2020-12-12

本人大叔一枚&#xff0c;自1992年接觸電腦&#xff0c;持續了30年的業余電腦發燒愛好者&#xff0c;2022年CSDN博客之星Top58&#xff0c;阿里云社區“乘風者計劃”專家博主。自某不知名財校畢業后進入國有大行工作至今&#xff0c;先后任職于某分行信息科技部、電子銀行部、金…

C語言面試之旅:掌握基礎,探索深度(面試實戰之單片機并行存儲器擴展)

引言 在嵌入式系統和微控制器等應用中&#xff0c;存儲器是至關重要的組成部分。單片機通常具有有限的內核存儲器和外部接口&#xff0c;因此擴展存儲器成為許多應用的必要步驟。本文將探討單片機并行存儲器擴展的各個方面。 1、單片機并行擴展總線 并行存儲器擴展是一種將…

《第一行代碼:Android》第三版7.4SQLite數據庫存儲

布局文件略過&#xff0c;就是五個按鈕&#xff0c;點擊按鈕執行對應的功能。 Android 專門提供了一個SQLiteOpenHelper幫助類來對數據庫進行創建和升級。 自己創建一個類繼承自SQLiteOpenHelper,重新寫onCreate()方法和onUpgrade()方法&#xff0c;分別對應創建數據庫和升級…

扔掉xshell,基于 QT 實現一個串口命令行工具(帶源碼)

背景 xshell 帶有支持串口的命令行能力&#xff0c; 可以方便的和下位機用命令進行交互&#xff0c;如下圖所示&#xff1a; msh > msh > msh >version\ | / - RT - Thread Operating System/ | \ 3.1.3 build Nov 7 20232006 - 2019 Copyright by rt-thre…

this.$emit(‘update:isVisible‘, false)作用

這個寫是不是很新穎&#xff0c;傳父組件傳值&#xff01;這是什么鬼。。。 假設你有以下邏輯業務。在A頁面彈出一個組件B&#xff0c;A組件里面使用B組件&#xff0c;是否展示B組件你使用的是baselineShow變量控制&#xff01; <BaselineData :isVisible.sync"basel…

如何在Word中簡潔地插入代碼

如何在Word中簡潔地插入代碼 背景&#xff1a; ? 最近在一寫一些論文或者報告的時候&#xff0c;需要將源代碼放在論文的最后&#xff0c;有一個很頭疼的問題&#xff0c;如果直接把代碼從編輯器復制到word中&#xff0c;就變成了下面這個樣子&#xff1a; 這有點丑陋啊&…

Qt簡介、C++工程文件分離、創建Qt工程、Qt的幫助文檔

QT 簡介 core&#xff1a;核心模塊&#xff0c;非圖形的接口類&#xff0c;為其它模塊提供支持 gui&#xff1a;圖形用戶接口&#xff0c;qt5之前 widgets&#xff1a;圖形界面相關的類模塊 qt5之后的 database&#xff1a;數據庫模塊 network&#xff1a;網絡模塊 QT 特性 開…

Linux系統的各項命令

文章目錄 Linux系統的目錄結構Linux路徑的描述方式Linux命令入門**什么是命令、命令行**Linux命令基礎格式 ls命令入門HOME目錄和工作目錄ls命令的參數和選項ls命令的 -a選項ls命令的 -l選項ls命令選項的組合使用ls選項和參數的組合使用ls命令的 -h選項 目錄切換相關命令&#…

多線程案例-阻塞隊列

阻塞隊列是什么 阻塞隊列是一種特殊的隊列.也遵循"先進先出"的原則 阻塞隊列能是一種線程安全的數據結構,并且具有以下特性: 當隊列滿的時候,繼續入隊列就會阻塞,直到有其他線程從隊列中取走元素. 當隊列空的時候,繼續出隊列也會阻塞,直到有其他線程往隊列中插入元素…

這七款網工在線畫拓撲工具,絕了!

你們好&#xff0c;我的網工朋友。 畫拓撲圖&#xff0c;絕對是網絡工程師的基操。 上次給你來了篇手把手教你繪制拓撲圖的好文&#xff0c;還沒看過的先去看啊&#xff1a;《網絡拓撲圖怎么畫最好&#xff1f;》。 關于畫拓撲的工具&#xff0c;那就多了&#xff0c;直接用…

數據結構與算法-D8D9隊列實現及應用

隊列&#xff1a;限制在兩端進行插入和刪除的線性表 允許進行存入操作的一端為“隊尾” 允許進行刪除操作的一端為“隊頭” 順序隊列 注意&#xff1a;front指向隊頭元素的位置 rear指向隊尾元素的下一個位置 實現循環隊列&#xff1a;(rear1)%N取余&#xff0c;為了區分空…

Connection refused: no further information

解決目錄 一、報錯信息二、解決方法 一、報錯信息 二、解決方法 1、報錯原因是開啟了代理&#xff0c;像AS是絕對不能開代理的。 2、設置為No proxy&#xff0c;然后Apply再選擇OK&#xff0c;重新同步。 要遠離消耗你的人和事&#xff0c;不要花費任何情緒或者精力在他們身…

unity Pc獲取本機Mac地址

1.此方法只能獲取眾多Mac中的一個 private static string GetMacAddress(){string physicalAddress "";NetworkInterface[] nice NetworkInterface.GetAllNetworkInterfaces();foreach (NetworkInterface adaper in nice){Debug.Log(adaper.Description);if (adape…