Java數(shù)據(jù)結(jié)構(gòu)與算法學(xué)習(xí)之循環(huán)鏈表

存儲(chǔ)結(jié)構(gòu)示意圖

優(yōu)點(diǎn) : 能夠通過任意結(jié)點(diǎn)遍歷整個(gè)鏈表結(jié)構(gòu)
初始化循環(huán)鏈表?
1.循環(huán)鏈表的結(jié)點(diǎn)
typedef struct CircularNode {
ElementType date; //數(shù)據(jù)域
struct CircularNode* next; //指向下一個(gè)結(jié)點(diǎn)的指針域
}CircularNode;
2.循環(huán)鏈表結(jié)構(gòu)
typedef struct CircularLinkList {
CircularNode* next; //指向第一個(gè)結(jié)點(diǎn)的頭指針,頭指針
int length;
}CircularLinkList;
循環(huán)鏈表的插入
需要考慮兩種情況
1.插入的鏈表長(zhǎng)度為 0? ?node -> next = node;
2.插入的鏈表長(zhǎng)度不為0 node -> next = clList -> next? ?lastNode -> next = node?
首位置

?
代碼實(shí)現(xiàn)

其他位置


代碼實(shí)現(xiàn)(總)
void InsertCircularLinkList(CircularLinkList* clList, int pos, ElementType element)
{
//創(chuàng)建一個(gè)空節(jié)點(diǎn)
CircularLinkList* node = (CircularLinkList*)malloc(sizeof(CircularLinkList));
node->date = element;
node->next = NULL;
if (pos == 1) {
node->next = clList->next;
if (!node->next) {
//如果插入的鏈表長(zhǎng)度為0
node->next = node;
}
else {
//如果長(zhǎng)度不為0,就要找到鏈表的最后一個(gè)結(jié)點(diǎn)并改變其指針域
CircularLinkList* lastNode = clList->next;
for (int i = 1; i < clList->length; i++)
{
lastNode = lastNode->next;
}
clList->next = node;
clList->length++;
}
return;
}
//插入的不是第一個(gè)結(jié)點(diǎn)
CircularLinkList* currNode = clList->next;
for (int i = 1; i < pos - 1; i++)
currNode = currNode->next;
if (currNode) {
node->next = currNode->next;
currNode->next = node;
clList->length++;
if (pos == clList->length) {
node->next = clList->next;
}
}
}
循環(huán)鏈表的刪除
1.操作的為第一個(gè)元素

代碼實(shí)現(xiàn)

2.操作元素不為第一個(gè)元素

代碼實(shí)現(xiàn)

代碼實(shí)現(xiàn)(總)
ElementType DeleteCircularLinkList(CircularLinkList* clList, int pos)
{
ElementType element;
element.id = -999;
if (pos == 1) {
CircularLinkList* node = clList->next;
if (node) {
//找到最后一個(gè)結(jié)點(diǎn),改變其指針域的指向
CircularLinkList* lastNode = clList->next;
for (int i = 1; i < clList->length; i++) {
lastNode = lastNode->next;
}
clList->next = node->next;
lastNode->next = clList->next;
free(node);
clList->length--;
}
return;
}
CircularLinkList* preNode;
CircularLinkList* node = clList->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);
clList->length--;
}
return element;
}
循環(huán)鏈表的常見操作?
已知 P 結(jié)點(diǎn)是循環(huán)鏈表的中間結(jié)點(diǎn),通過該節(jié)點(diǎn)遍歷循環(huán)鏈表


代碼實(shí)現(xiàn)
CircularNode* GetCircularLinkListNode(CircularLinkList* clList, ELementType element)
{
CircularNode* node = clList->next;
if (!node) return NULL;
do {
if (element.id == node->date.id && strcmp(element.name, node->date.name) == 0) {
return node;
}
} while (node == clList->next);
return NULL;
}
以上就是Java數(shù)據(jù)結(jié)構(gòu)與算法學(xué)習(xí)之循環(huán)鏈表的詳細(xì)內(nèi)容,更多關(guān)于Java數(shù)據(jù)結(jié)構(gòu) 循環(huán)鏈表的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之單向鏈表
- Java 數(shù)據(jù)結(jié)構(gòu)與算法系列精講之環(huán)形鏈表
- 帶你了解Java數(shù)據(jù)結(jié)構(gòu)和算法之鏈表
- Java實(shí)現(xiàn)鏈表數(shù)據(jù)結(jié)構(gòu)的方法
- Java數(shù)據(jù)結(jié)構(gòu)與算法學(xué)習(xí)之雙向鏈表
- Java 數(shù)據(jù)結(jié)構(gòu)之刪除鏈表中重復(fù)的結(jié)點(diǎn)
- java數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)雙向鏈表功能
- Java數(shù)據(jù)結(jié)構(gòu)之順序表和鏈表精解
- Java?精煉解讀數(shù)據(jù)結(jié)構(gòu)的鏈表的概念與實(shí)現(xiàn)
相關(guān)文章
利用java監(jiān)聽器實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì)
過去使用ASP和ASP.NET兩種編程的時(shí)候,都寫過在線人數(shù)統(tǒng)計(jì)能,實(shí)現(xiàn)功能挺簡(jiǎn)單的!今天使用java來實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì)有點(diǎn)另類,是通過Java監(jiān)聽器實(shí)現(xiàn)的,需要的朋友可以參考下2015-09-09
Java調(diào)用第三方接口封裝實(shí)現(xiàn)
本文主要介紹了Java調(diào)用第三方接口封裝實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
Java多條件判斷場(chǎng)景中規(guī)則執(zhí)行器的設(shè)計(jì)
近日在公司領(lǐng)到一個(gè)小需求,需要對(duì)之前已有的試用用戶申請(qǐng)規(guī)則進(jìn)行拓展。本文去掉if 判斷,試試用一個(gè)規(guī)則執(zhí)行器來替代它,感興趣的可以了解一下2021-06-06
JDBC鏈接數(shù)據(jù)庫(kù)的幾個(gè)步驟
這篇文章主要介紹了JDBC鏈接數(shù)據(jù)庫(kù)的幾個(gè)步驟,通過將數(shù)據(jù)庫(kù)的連接放在一個(gè)工具類里面,達(dá)到重用的效果,需要的朋友可以參考下2015-07-07
springboot集成nacos無法動(dòng)態(tài)獲取nacos配置的問題
這篇文章主要介紹了springboot集成nacos無法動(dòng)態(tài)獲取nacos配置的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09

