日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > > 充電吧
[導(dǎo)讀]1、線性表的定義---- 通常,定義線性表為n(n>=0)個(gè)數(shù)據(jù)元素(或稱為表元)的有限序列。記為L(zhǎng)=(a1,a2,...,an). 其中L是表名,ai是表中的結(jié)點(diǎn),是不可再分割的數(shù)據(jù)。n是表中

1、線性表的定義

---- 通常,定義線性表為n(n>=0)個(gè)數(shù)據(jù)元素(或稱為表元)的有限序列。記為L(zhǎng)=(a1,a2,...,an). 其中L是表名,ai是表中的結(jié)點(diǎn),

是不可再分割的數(shù)據(jù)。n是表中表元的個(gè)數(shù),也稱為表的長(zhǎng)度,若n=0叫做空表。

---- 在非空的數(shù)據(jù)元素集合中,線性表的特點(diǎn)是:

--- ?1)存在唯一的一個(gè)稱作“第一個(gè)”的元素。

--- ?2)存在唯一的一個(gè)稱作“最后一個(gè)”的元素。

--- ?3)除第一個(gè)元素外,集合中的每個(gè)元素均只有一個(gè)直接前驅(qū)。

--- ?4)除最后一個(gè)元素外,集合中的每個(gè)元素均只有一個(gè)直接后繼。

其中3)4)兩個(gè)特點(diǎn)體現(xiàn)了線性表中元素之間的邏輯關(guān)系。

理解線性表的要點(diǎn):

--- 表中元素具有邏輯上的順序性,在序列中各元素排列有其先后次序。

--- 表中元素個(gè)數(shù)有限。

--- 表中元素都是數(shù)據(jù)元素。即每一個(gè)表元素都是不可再分的原子數(shù)據(jù)。

--- 表中元素的數(shù)據(jù)類型都相同。即每一個(gè)表元素占有相同數(shù)量的存儲(chǔ)空間。

--- 表中元素具有抽象性。僅討論表元素之間的邏輯關(guān)系,不考慮元素究竟表示什么內(nèi)容。

2、線性表的操作

---- 線性表的主要操作有:

--- ?1)表的初始化運(yùn)算:將線性表置為空表。

--- ?2)求表長(zhǎng)度運(yùn)算:統(tǒng)計(jì)線性表中表元素個(gè)數(shù)。

--- ?3)查找運(yùn)算:查找線性表中第i個(gè)表元素或查找表中具有給定關(guān)鍵字值的表元素。

--- ?4)插入運(yùn)算:將新表元素插入到線性表第i個(gè)位置上,或插入到具有給定關(guān)鍵字值的表元素的前面或后面。

--- ?5)刪除運(yùn)算:刪除線性表第i個(gè)表元素或具有給定關(guān)鍵字值的表元素。

--- ?6)讀?。ㄔL問)運(yùn)算:讀取線性表第i個(gè)表元素的值。

--- ?7)復(fù)制運(yùn)算:復(fù)制線性表所有表元素到另一個(gè)線性表中。

3、線性表的實(shí)現(xiàn)

3.1、線性表的順序存儲(chǔ)

------ 線性表的順序存儲(chǔ)又稱為順序表。它用一組地址連續(xù)的存儲(chǔ)單元依次存儲(chǔ)線性表中的數(shù)據(jù)元素,從而使得邏輯關(guān)系相鄰的兩個(gè)

元素在物理位置上也相鄰。因此順序表的特點(diǎn)是表中各元素的邏輯順序與其物理順序相同。

------ 順序表的靜態(tài)存儲(chǔ)分配


#define?MaxSize?100?????????//顯式的定義表的最大容量
typedef?int?ElemType;???????//定義表元素的數(shù)據(jù)類型
typedef?struct?{????????????//順序表的定義
	ElemType?data[MaxSize];?//靜態(tài)分配存儲(chǔ)表元素的數(shù)組
	int?n;??????????????????//實(shí)際表元素個(gè)數(shù),0<=n<=MaxSize
}Sqlist;

在這種存儲(chǔ)方式下,表元素ai存儲(chǔ)在data[i-1]位置,存儲(chǔ)結(jié)構(gòu)如下圖:

假設(shè)順序表A的起始存儲(chǔ)位置為L(zhǎng)oc(1),第i個(gè)表項(xiàng)的存儲(chǔ)位置為L(zhǎng)oc(i),則有:Loc(i)=Loc(1)+(i-1) x sizeof(ElemType)

其中,Loc(1)是第一個(gè)表項(xiàng)的存儲(chǔ)位置,即數(shù)組中第0個(gè)元素位置。sizeof(ElemType)是表中每個(gè)元素所占空間的大小。根據(jù)這個(gè)計(jì)算

關(guān)系,可隨機(jī)存取表中的任一個(gè)元素。一維數(shù)組可以是靜態(tài)分配的,也可以是動(dòng)態(tài)分配的。

----- ?在靜態(tài)分配存儲(chǔ)的情形下,由于數(shù)組的大小和空間事先已經(jīng)固定分配,一旦數(shù)據(jù)空間占滿,再加入新的數(shù)據(jù)就將產(chǎn)生溢出,此時(shí)

存儲(chǔ)空間不能擴(kuò)充,就會(huì)導(dǎo)致程序停止工作。

----- ?在動(dòng)態(tài)分配存儲(chǔ)的情形下,存儲(chǔ)數(shù)組的空間是在程序執(zhí)行過程中通過動(dòng)態(tài)存儲(chǔ)分配的語句分配的,一旦數(shù)據(jù)空間占滿,可以另外

再分配一塊更大的存儲(chǔ)空間,用以代換原來的存儲(chǔ)空間,從而達(dá)到擴(kuò)充存儲(chǔ)數(shù)組空間的目的,同時(shí)需將表示數(shù)組大小的常量maxSize

放在順序表的結(jié)構(gòu)內(nèi)定義,可以動(dòng)態(tài)地記錄擴(kuò)充后數(shù)組空間的大小,提高結(jié)構(gòu)的靈活性。

------ 順序表的動(dòng)態(tài)存儲(chǔ)分配


#define?InitSize?100		//表長(zhǎng)度的初始定義
typedef?int?ElemType;		//定義表元素的數(shù)據(jù)類型
typedef?struct?{		//順序表的定義
	ElemType?*data;		//指示動(dòng)態(tài)分配數(shù)組的指針
	int?maxSize,n;		//數(shù)據(jù)的最大容量和當(dāng)前表元素的個(gè)數(shù)
}Seqlist;
//初始的動(dòng)態(tài)分配語句為
data?=?(ElemType?*)malloc(sizeof(ElemType)*InitSize);
//C++?data=new?ElemType[InitSize];
maxSize?=?InitSize;n=0;

3.2、線性表的鏈?zhǔn)酱鎯?chǔ)

------ ?線性表的鏈?zhǔn)酱鎯?chǔ)又稱為線性鏈表。在這種結(jié)構(gòu)中數(shù)據(jù)元素存儲(chǔ)在結(jié)點(diǎn)中,結(jié)點(diǎn)之間在空間上可以連續(xù),也可以不連續(xù),通過

結(jié)點(diǎn)內(nèi)附的鏈接指針來表示元素之間的邏輯關(guān)系。因此在線性鏈表中邏輯上相鄰的表元素在物理上不一定相鄰。

以前在順序結(jié)構(gòu)中,每個(gè)數(shù)據(jù)元素只需要存數(shù)據(jù)元素信息就可以了,現(xiàn)在鏈?zhǔn)浇Y(jié)構(gòu)中,除了要存數(shù)據(jù)元素信息外,還要存儲(chǔ)它的后繼

元素的存儲(chǔ)地址。因此,為了表示每個(gè)數(shù)據(jù)元素ai與其直接后繼數(shù)據(jù)元素a(i+1)之間的邏輯關(guān)系,對(duì)數(shù)據(jù)元素ai來說,除了存儲(chǔ)其本身

的信息之外,還需存儲(chǔ)一個(gè)指示其直接后繼的信息(即直接后繼的存儲(chǔ)地址/位置)。

------ ?存儲(chǔ)數(shù)據(jù)元素信息的域稱為數(shù)據(jù)域,存儲(chǔ)直接后繼位置的域稱為指針域。指針域中存儲(chǔ)的信息稱做指針或鏈。這兩部分信息組成

數(shù)據(jù)元素ai的存儲(chǔ)映像,稱為結(jié)點(diǎn)(Node)。n個(gè)結(jié)點(diǎn)鏈接成一個(gè)鏈表,即為線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。

最簡(jiǎn)單的線性鏈表是單鏈表(鏈表的每個(gè)結(jié)點(diǎn)中只包含一個(gè)指針域),用C語言描述如下:

typedef?int?ElemType;		//定義表元素的數(shù)據(jù)類型
typedef?struct?node?{		
	ElemType?data;
	struct?node?*next;
}Node,*LinkList;

此時(shí),使用一個(gè)指向鏈表結(jié)點(diǎn)的指針head標(biāo)識(shí)鏈表的表頭:

Node?*head;LinkList?head;

為了表示鏈表收尾,鏈表最后一個(gè)結(jié)點(diǎn)的鏈接指針應(yīng)置為空。

4、其他線性鏈表的形式

---- 根據(jù)結(jié)點(diǎn)中指針信息的實(shí)現(xiàn)方式,還有其他幾種鏈表結(jié)構(gòu):

--- ?1)雙向鏈表:每個(gè)結(jié)點(diǎn)包含兩個(gè)指針,指明直接前驅(qū)和直接后繼元素,可在兩個(gè)方向上遍歷其后及其前的元素。

--- ?2)循環(huán)鏈表:表尾結(jié)點(diǎn)的后繼指針指向表中的第一個(gè)結(jié)點(diǎn),可在任何位置上遍歷整個(gè)鏈表。

--- ?3)靜態(tài)鏈表:借助數(shù)組來描述線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。(兩個(gè)數(shù)據(jù)域,一個(gè)存放數(shù)據(jù)元素,一個(gè)存儲(chǔ)該元素的后繼在數(shù)組中的下標(biāo))

在鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)中,只需要一個(gè)指針(頭指針)指向第一個(gè)結(jié)點(diǎn),就可以順序訪問到表中的任意一個(gè)元素。為了簡(jiǎn)化對(duì)鏈表狀態(tài)的判定

和處理,特別引入一個(gè)不存儲(chǔ)數(shù)據(jù)元素的結(jié)點(diǎn),稱為頭結(jié)點(diǎn),將其作為鏈表的第一個(gè)結(jié)點(diǎn)并令頭指針指向該結(jié)點(diǎn)。

頭結(jié)點(diǎn)的數(shù)據(jù)域可以不存儲(chǔ)任何信息,也可以存儲(chǔ)如線性表長(zhǎng)度等類的附加信息,頭結(jié)點(diǎn)的指針域存儲(chǔ)指向第一個(gè)結(jié)點(diǎn)的指針(即第一個(gè)

元素結(jié)點(diǎn)的存儲(chǔ)位置)。此時(shí),單鏈表的頭指針指向頭結(jié)點(diǎn)。如下圖所示:




本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉