C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表的查找和建立
單鏈表的查找
其實(shí)在單鏈表的插入和刪除中,我們已經(jīng)使用過(guò)單鏈表的查找方法,因?yàn)椴迦牒蛣h除的前提都是先找到對(duì)應(yīng)的結(jié)點(diǎn),所以這里就不再多解釋
按位查找
GetElem(L, i):按位查找操作。獲取表 L 中第 i 個(gè)位置的元素的值
//按位查找
LNode * GetElem(LinkList L, int i) {
if (i < 0) return false;
LNode *p; //指針p指向當(dāng)前掃描到的結(jié)點(diǎn)
int j = 0; //當(dāng)前p指向的是第幾個(gè)結(jié)點(diǎn)
p = L; //L指向頭結(jié)點(diǎn),頭結(jié)點(diǎn)是第 0 個(gè)結(jié)點(diǎn)
//循環(huán)找到第 i-1 個(gè)結(jié)點(diǎn)
while (p != NULL && j < i) {
p = p->next;
j++;
}
return p;
}
按值查找
LocateElem(L, e):按值查找操作。在表 L 中查找具有給定關(guān)鍵字值的元素
//按值查找
LNode * LocateElem(LinkList L, ElemType e) {
LNode *p = L->next;
//從第1個(gè)結(jié)點(diǎn)開(kāi)始查找數(shù)據(jù)域?yàn)閑的結(jié)點(diǎn)
while (p && p->data != e) {
p = p->next;
}
return p;單鏈表的建立
如果給你很多個(gè)數(shù)據(jù)元素(ElemType),要把它們存到一個(gè)單鏈表里面,怎么操作呢?
第一步:初始化一個(gè)單鏈表
第二步:每次取一個(gè)數(shù)據(jù)元素,插入到表尾/表頭
尾插法
算法步驟:
1.創(chuàng)建一個(gè)只有頭結(jié)點(diǎn)的空鏈表
2.尾指針 r 初始化,指向頭結(jié)點(diǎn)
3.接收用戶(hù)輸入的值,判斷是否結(jié)束插入,不結(jié)束則插入表中
- 創(chuàng)建新結(jié)點(diǎn) *s
- 將用戶(hù)輸入的值賦給新節(jié)點(diǎn) *s 的數(shù)據(jù)域
- 將新節(jié)點(diǎn) *s 插入到尾結(jié)點(diǎn) *r 之后
- 尾指針 r 指向新的尾結(jié)點(diǎn) *s
- 用戶(hù)繼續(xù)輸入
//尾插法建立單鏈表
LinkList List_TailInsert(LinkList &L) {
int x; //假設(shè)ElemType為整型
L = (LinkList)malloc(sizeof(LNode)); //建立頭結(jié)點(diǎn)
LNode *s, *r = L; //r為表尾指針
scanf("%d", &x); //輸入結(jié)點(diǎn)的值
while (x != 9999) { //輸入9999表示結(jié)束
s = (LNode *)malloc(sizeof(LNode));
s->data = x;
r->next = s;
r = s; //r指向新的表尾結(jié)點(diǎn)
scanf("%d", &x);
}
r->next = NULL; //尾結(jié)點(diǎn)指針置空
return L;
}頭插法建立單鏈表
算法步驟:
1.創(chuàng)建一個(gè)只有頭結(jié)點(diǎn)的空鏈表
2.接收用戶(hù)輸入的值,判斷是否結(jié)束插入,不結(jié)束則插入表中
- 創(chuàng)建新結(jié)點(diǎn) *s
- 將用戶(hù)輸入的值賦給新節(jié)點(diǎn) *s 的數(shù)據(jù)域
- 將新節(jié)點(diǎn) *s 插入到頭結(jié)點(diǎn)之后
- 用戶(hù)繼續(xù)輸入
//頭插法建立單鏈表
LinkList List_HeadInsert(LinkList &L) {
LNode *s;
int x; //假設(shè)ElemType為整型
L = (LinkList)malloc(sizeof(LNode)); //建立頭結(jié)點(diǎn)
L->next = NULL;
scanf("%d", &x); //輸入結(jié)點(diǎn)的值
while (x != 9999) { //輸入9999表示結(jié)束
s = (LNode *)malloc(sizeof(LNode));
s->data = x;
s->next = L->next;
L->next = s;
scanf("%d", &x);
}
return L;
}記得 L->next = NULL; 這一句不能漏了,不然會(huì)出問(wèn)題
到此這篇關(guān)于C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表的查找和建立的文章就介紹到這了,更多相關(guān)C語(yǔ)言單鏈表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ 復(fù)制控制之復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn)
所謂的“復(fù)制控制”即通過(guò)這三個(gè)成員函數(shù)控制對(duì)象復(fù)制的過(guò)程,本文主要介紹了C++ 復(fù)制控制之復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11
C++函數(shù)的嵌套調(diào)用和遞歸調(diào)用學(xué)習(xí)教程
這篇文章主要介紹了C++函數(shù)的嵌套調(diào)用和遞歸調(diào)用學(xué)習(xí)教程,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09
一文帶你了解Qt多線(xiàn)程的實(shí)現(xiàn)方式
這篇文章主要為大家詳細(xì)介紹了Qt多線(xiàn)程的實(shí)現(xiàn)方式的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-01-01
基于QT和百度云api實(shí)現(xiàn)批量獲取PDF局部文字內(nèi)容
這篇文章將為大家介紹如何使用 QT 構(gòu)建圖形用戶(hù)界面,結(jié)合百度云 OCR API 實(shí)現(xiàn)批量獲取 PDF 局部文字內(nèi)容并對(duì)文件進(jìn)行改名的功能,需要的可以參考下2025-03-03
C語(yǔ)言數(shù)據(jù)的存儲(chǔ)專(zhuān)項(xiàng)分析
使用編程語(yǔ)言進(jìn)行編程時(shí),需要用到各種變量來(lái)存儲(chǔ)各種信息。變量保留的是它所存儲(chǔ)的值的內(nèi)存位置。這意味著,當(dāng)您創(chuàng)建一個(gè)變量時(shí),就會(huì)在內(nèi)存中保留一些空間。您可能需要存儲(chǔ)各種數(shù)據(jù)類(lèi)型的信息,操作系統(tǒng)會(huì)根據(jù)變量的數(shù)據(jù)類(lèi)型,來(lái)分配內(nèi)存和決定在保留內(nèi)存中存儲(chǔ)什么2022-07-07
C語(yǔ)言中十六進(jìn)制轉(zhuǎn)十進(jìn)制兩種實(shí)現(xiàn)方法
這篇文章主要介紹了C語(yǔ)言中十六進(jìn)制轉(zhuǎn)十進(jìn)制兩種實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下2017-01-01
C++ OpenCV制作黑客帝國(guó)風(fēng)格的照片
這篇文章主要介紹了如何通過(guò)C++ OpenCV制作出黑客帝國(guó)風(fēng)格的照片,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)OpenCV有一定幫助,需要的可以參考一下2022-01-01

