亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2021年12月28日 09:48:19   作者:玄澈_  
循環(huán)鏈表是另一種形式的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。它的特點(diǎn)是表中最后一個(gè)結(jié)點(diǎn)的指針域指向頭結(jié)點(diǎn),整個(gè)鏈表形成一個(gè)環(huán)。本文將為大家詳細(xì)介紹一下循環(huán)鏈表的特點(diǎn)與使用,需要的可以了解一下

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

優(yōu)點(diǎn) : 能夠通過(guò)任意結(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)鏈表的常見(jiàn)操作?

已知 P 結(jié)點(diǎn)是循環(huán)鏈表的中間結(jié)點(diǎn),通過(guò)該節(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)文章!

相關(guān)文章

  • 利用java監(jiān)聽(tīng)器實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì)

    利用java監(jiān)聽(tīng)器實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì)

    過(guò)去使用ASP和ASP.NET兩種編程的時(shí)候,都寫(xiě)過(guò)在線人數(shù)統(tǒng)計(jì)能,實(shí)現(xiàn)功能挺簡(jiǎn)單的!今天使用java來(lái)實(shí)現(xiàn)在線人數(shù)統(tǒng)計(jì)有點(diǎn)另類,是通過(guò)Java監(jiān)聽(tīng)器實(shí)現(xiàn)的,需要的朋友可以參考下
    2015-09-09
  • Java調(diào)用第三方接口封裝實(shí)現(xiàn)

    Java調(diào)用第三方接口封裝實(shí)現(xiàn)

    本文主要介紹了Java調(diào)用第三方接口封裝實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • Java多條件判斷場(chǎng)景中規(guī)則執(zhí)行器的設(shè)計(jì)

    Java多條件判斷場(chǎng)景中規(guī)則執(zhí)行器的設(shè)計(jì)

    近日在公司領(lǐng)到一個(gè)小需求,需要對(duì)之前已有的試用用戶申請(qǐng)規(guī)則進(jìn)行拓展。本文去掉if 判斷,試試用一個(gè)規(guī)則執(zhí)行器來(lái)替代它,感興趣的可以了解一下
    2021-06-06
  • Java深度復(fù)制功能與用法實(shí)例分析

    Java深度復(fù)制功能與用法實(shí)例分析

    這篇文章主要介紹了Java深度復(fù)制功能與用法,簡(jiǎn)單講述了深度復(fù)制的概念、功能并結(jié)合實(shí)例形式分析了java實(shí)現(xiàn)深度復(fù)制的具體操作技巧,需要的朋友可以參考下
    2018-01-01
  • 為何找不到Java 7中的警告

    為何找不到Java 7中的警告

    在本篇文章和里小編給大家整理的是關(guān)于Java 7中的警告的相關(guān)知識(shí)點(diǎn)內(nèi)容,有需要的朋友們可以參考下。
    2019-11-11
  • JDBC鏈接數(shù)據(jù)庫(kù)的幾個(gè)步驟

    JDBC鏈接數(shù)據(jù)庫(kù)的幾個(gè)步驟

    這篇文章主要介紹了JDBC鏈接數(shù)據(jù)庫(kù)的幾個(gè)步驟,通過(guò)將數(shù)據(jù)庫(kù)的連接放在一個(gè)工具類里面,達(dá)到重用的效果,需要的朋友可以參考下
    2015-07-07
  • springboot集成nacos無(wú)法動(dòng)態(tài)獲取nacos配置的問(wèn)題

    springboot集成nacos無(wú)法動(dòng)態(tài)獲取nacos配置的問(wèn)題

    這篇文章主要介紹了springboot集成nacos無(wú)法動(dòng)態(tài)獲取nacos配置的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Java中的Spring Security配置過(guò)濾器

    Java中的Spring Security配置過(guò)濾器

    這篇文章主要介紹了Java中的Spring Security配置過(guò)濾器,文章通過(guò)圍繞文章主題的相關(guān)資料展開(kāi)詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05
  • java異步上傳圖片示例

    java異步上傳圖片示例

    這篇文章主要介紹了java異步上傳圖片示例,需要的朋友可以參考下
    2014-02-02
  • Java的枚舉,注解和反射(一)

    Java的枚舉,注解和反射(一)

    今天小編就為大家分享一篇關(guān)于Java枚舉,注解與反射原理說(shuō)明,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2021-07-07

最新評(píng)論