欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言數(shù)據(jù)結(jié)構(gòu)與算法之單鏈表

 更新時間:2021年12月23日 14:22:50   作者:玄澈_  
單鏈表是一種鏈式存取的數(shù)據(jù)結(jié)構(gòu),用一組地址任意的存儲單元存放線性表中的數(shù)據(jù)元素。本文將為大家介紹C語言中單鏈表的基本概念與讀取數(shù)據(jù)元素,需要的可以參考一下

基本概念

鏈表的每一個結(jié)點中只包含一個指針域

優(yōu)點 : 儲存空間利用高效

舉例來說:

typedef struct student{
	int id;		//學生編號
	char* name; //學生名稱
 
	//指向下一結(jié)點的指針
	struct Student* pNext;
}Student;

與之相反的是多鏈表

typedef struct student{
	int id;		//學生編號
	char* name; //學生名稱
 
	//指向下一結(jié)點的指針
	struct Student* pNext;
	struct Student* qNext;
}Student;

讀取數(shù)據(jù)元素

獲取第i個結(jié)點的數(shù)據(jù)元素

  1. 聲明一個結(jié)點指針p指向鏈表的第一個結(jié)點a1,初始化j從1開始
  2. 當j < i 時,遍歷鏈表,讓p的指針向后移動,不斷指向下一個結(jié)點,j 累加 1
  3. 當鏈表末尾 p 為空時,則說明第 i 個元素不存在;否則查找成功,返回結(jié)點 p 的數(shù)據(jù)

?

1.定義數(shù)據(jù)元素

//定義數(shù)據(jù)元素
typedef struct student{
	int id;		
	char* name; 
}ElementType;

2.定義順序表結(jié)構(gòu)

typedef struct {
	ElementType dates[MAX_SIZE];   //當前順序表中的數(shù)據(jù)集合
	int length;					   //當前順序表中的元素個數(shù)
 
}SeqList;

3.定義鏈表的結(jié)點(包括數(shù)據(jù)域和指針域)

typedef struct Node {
	ElementType date;  //數(shù)據(jù)域
	struct Node* node; //指針域,指向下一個結(jié)點
}Node;

4.設置頭結(jié)點

我們在定義鏈表時,習慣性的會定義頭結(jié)點,以便統(tǒng)一鏈表結(jié)點的插入和刪除操作

typedef struct Linklist {
	Node* next;  //頭指針
	int length;
}Linklist;

如果鏈表有頭結(jié)點,next就指向頭結(jié)點,沒有就指向第一個結(jié)點

鏈表的長度初始值為0

插入數(shù)據(jù)元素?

在第i個結(jié)點后插入數(shù)據(jù)元素 ?

  1. 創(chuàng)建一個空節(jié)點,分配內(nèi)存空間,設置數(shù)據(jù)元素
  2. 獲取第i個結(jié)點,設置新結(jié)點的后繼結(jié)點為該結(jié)點的后繼結(jié)點
  3. 設置第i個結(jié)點的后繼結(jié)點為該結(jié)點

1.創(chuàng)建空節(jié)點并為數(shù)據(jù)域賦值

	//創(chuàng)建空節(jié)點并為數(shù)據(jù)賦值
	Node* node = (Node*)malloc(sizeof(Node));
    node -> date = element;
    node -> next = NULL;

2.通過循環(huán)找到要插入的結(jié)點

	for (int i = 1; currNode && i < pos - 1; i++)
	{
		currNode = currNode->next;
	}

3.將結(jié)點插入并對接前面的結(jié)點

	if (currNode) {
		node->next = currNode->next;
		currNode->next = node;
		linkList->length++;
	}

初始化鏈表

void InitLinkList(LinkList* linkList, ElementType* dateArrar, int length)
{
	for (int i = 0; i < length; i++) {
		InsertLinkList(linkList, i + 1, dateArrar[i]);
	}
}

打印鏈表

void PrintLinkList(LinkList* linklist)
{
	Node* node = linklist->next;
	if (!node)
	{
		printf("鏈表為空!\n");
		linklist->length = 0;
		return 0;
	}
	for (int i = 0; i < linklist->length; i++) {
		printf("%d\t%s\t\n", node->date.id, node->date.name);
        node = node->next;
	}
}

順序表查空

int IsLinkListEmpty(LinkList* linkList) {
 
	return linkList->length == 0 ? TRUE : FALSE;
 
}

順序表的刪除?

刪除第i個結(jié)點及其數(shù)據(jù)元素

  1. 獲取第i個結(jié)點,若該結(jié)點不是第一個結(jié)點,則獲取第i - 1個結(jié)點
  2. 將第i -1個結(jié)點的后綴結(jié)點設為第i個結(jié)點的后綴結(jié)點
  3. 刪除第i個結(jié)點,釋放內(nèi)存空間,記錄并返回刪除數(shù)據(jù)元素的值

情況1:當刪除的是第一個元素

	if (pos == 1)
	{
		node = linkList->next;
		if (node) {
			element = node->date;
			linkList->next = node->next;
			free(node);  //釋放被刪除的結(jié)點
			linkList->length--;
		}
        return element;
	}

情況2:除第一個結(jié)點外

  1. 找到要刪除的結(jié)點和他的前綴結(jié)點
  2. 要刪除結(jié)點的next 賦值給前綴結(jié)點
  3. 釋放要刪除的結(jié)點
	Node* preNode; //前綴結(jié)點
	node = linkList->next;
	for (int i = 1; node && i < pos; i++)
	{
		preNode = node;
		node = node->next;
	}
	if (node)
	{
		element = node->date;
		preNode->next = node->next;
		free(node);
		linkList->length--;
	}
	return element;

完整代碼

ElementType DeleteLinkListElement(LinkList* linkList, int pos)
{
	ElementType element;   //被刪除的元素
	element.id = -999;     //賦一個不可能的值,來判斷刪除是否成功
	Node* node = NULL;
 
	if (pos == 1)
	{
		node = linkList->next;
		if (node) {
			element = node->date;
			linkList->next = node->next;
			free(node);  //釋放被刪除的結(jié)點
			linkList->length--;
		}
	}
 
	Node* preNode; //前綴結(jié)點
	node = linkList->next;
	for (int i = 1; node && i < pos; i++)
	{
		preNode = node;
		node = node->next;
	}
	if (node)
	{
		element = node->date;
		preNode->next = node->next;
		free(node);
		linkList->length--;
	}
	return element;
 
}

刪除單鏈表整表

  1. 聲明結(jié)點p 和 q
  2. 將第一個結(jié)點賦值給p
  3. 循環(huán)將下一個結(jié)點賦值給q,釋放p,將q賦值給p

?

void CleatLinkList(LinkList* linkList)
{
	Node* node = linkList->next;
	Node* nextNode;
	while (node) {
		nextNode = node->next;  //先記錄當前結(jié)點的下一個結(jié)點,以便釋放當前結(jié)點的內(nèi)存
		free(node);
		node = nextNode;
	}
	linkList->next = NULL;
	linkList->length = 0;
}

單鏈表VS順序表

?

?

以上就是C語言數(shù)據(jù)結(jié)構(gòu)與算法之單鏈表的詳細內(nèi)容,更多關(guān)于C語言單鏈表的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 關(guān)于嘗試開發(fā)PHP的MYSQL擴展的使用

    關(guān)于嘗試開發(fā)PHP的MYSQL擴展的使用

    本篇文章小編將為大家介紹,關(guān)于嘗試開發(fā)PHP的MYSQL擴展的使用,需要的朋友可以參考一下
    2013-04-04
  • C語言實現(xiàn)線性表的基本操作詳解

    C語言實現(xiàn)線性表的基本操作詳解

    線性表是最基本、最簡單、也是最常用的一種數(shù)據(jù)結(jié)構(gòu)。一個線性表是n個具有相同特性的數(shù)據(jù)元素的有限序列,這篇文章帶你學習如何通過C語言實現(xiàn)線性表的順序存儲和鏈式存儲
    2021-11-11
  • C語言實現(xiàn)變色進度條

    C語言實現(xiàn)變色進度條

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)一個變色的進度條,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C語言深入探究動態(tài)規(guī)劃之線性DP

    C語言深入探究動態(tài)規(guī)劃之線性DP

    線性動態(tài)規(guī)劃,是較常見的一類動態(tài)規(guī)劃問題,其是在線性結(jié)構(gòu)上進行狀態(tài)轉(zhuǎn)移,這類問題不像背包問題、區(qū)間DP等有固定的模板,線性動態(tài)規(guī)劃的目標函數(shù)為特定變量的線性函數(shù),約束是這些變量的線性不等式或等式,目的是求目標函數(shù)的最大值或最小值
    2022-04-04
  • 關(guān)于Qt添加opencv和libtorch庫的問題

    關(guān)于Qt添加opencv和libtorch庫的問題

    這篇文章主要介紹了Qt添加opencv和libtorch庫的相關(guān)知識,兩種方法一種是通過手動添加,一種是通過qt creator添加,需要的朋友可以參考下
    2022-01-01
  • 解決Qt設置QTextEdit行高的問題

    解決Qt設置QTextEdit行高的問題

    這篇文章介紹了Qt設置QTextEdit行高的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • c++實現(xiàn)reactor高并發(fā)服務器的詳細教程

    c++實現(xiàn)reactor高并發(fā)服務器的詳細教程

    這篇文章主要介紹了c++從零實現(xiàn)reactor高并發(fā)服務器,包括環(huán)境準備和基礎知識介紹,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • c++自帶的查找函數(shù)詳解

    c++自帶的查找函數(shù)詳解

    這篇文章主要介紹了c++自帶的查找函數(shù),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • c++ 智能指針基礎詳解

    c++ 智能指針基礎詳解

    這篇文章主要介紹了c++ 智能指針基礎的相關(guān)資料,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下
    2021-02-02
  • Inline Hook(ring3)的簡單C++實現(xiàn)方法

    Inline Hook(ring3)的簡單C++實現(xiàn)方法

    這篇文章主要介紹了Inline Hook(ring3)的簡單C++實現(xiàn)方法,需要的朋友可以參考下
    2014-08-08

最新評論