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

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

1、線性表的定義

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

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

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

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

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

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

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

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

理解線性表的要點:

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

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

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

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

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

2、線性表的操作

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

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

--- ?2)求表長度運算:統(tǒng)計線性表中表元素個數(shù)。

--- ?3)查找運算:查找線性表中第i個表元素或查找表中具有給定關鍵字值的表元素。

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

--- ?5)刪除運算:刪除線性表第i個表元素或具有給定關鍵字值的表元素。

--- ?6)讀?。ㄔL問)運算:讀取線性表第i個表元素的值。

--- ?7)復制運算:復制線性表所有表元素到另一個線性表中。

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

3.1、線性表的順序存儲

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

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

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


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

在這種存儲方式下,表元素ai存儲在data[i-1]位置,存儲結構如下圖:

假設順序表A的起始存儲位置為Loc(1),第i個表項的存儲位置為Loc(i),則有:Loc(i)=Loc(1)+(i-1) x sizeof(ElemType)

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

關系,可隨機存取表中的任一個元素。一維數(shù)組可以是靜態(tài)分配的,也可以是動態(tài)分配的。

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

存儲空間不能擴充,就會導致程序停止工作。

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

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

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

------ 順序表的動態(tài)存儲分配


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

3.2、線性表的鏈式存儲

------ ?線性表的鏈式存儲又稱為線性鏈表。在這種結構中數(shù)據(jù)元素存儲在結點中,結點之間在空間上可以連續(xù),也可以不連續(xù),通過

結點內附的鏈接指針來表示元素之間的邏輯關系。因此在線性鏈表中邏輯上相鄰的表元素在物理上不一定相鄰。

以前在順序結構中,每個數(shù)據(jù)元素只需要存數(shù)據(jù)元素信息就可以了,現(xiàn)在鏈式結構中,除了要存數(shù)據(jù)元素信息外,還要存儲它的后繼

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

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

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

數(shù)據(jù)元素ai的存儲映像,稱為結點(Node)。n個結點鏈接成一個鏈表,即為線性表的鏈式存儲結構。

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

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

此時,使用一個指向鏈表結點的指針head標識鏈表的表頭:

Node?*head;LinkList?head;

為了表示鏈表收尾,鏈表最后一個結點的鏈接指針應置為空。

4、其他線性鏈表的形式

---- 根據(jù)結點中指針信息的實現(xiàn)方式,還有其他幾種鏈表結構:

--- ?1)雙向鏈表:每個結點包含兩個指針,指明直接前驅和直接后繼元素,可在兩個方向上遍歷其后及其前的元素。

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

--- ?3)靜態(tài)鏈表:借助數(shù)組來描述線性表的鏈式存儲結構。(兩個數(shù)據(jù)域,一個存放數(shù)據(jù)元素,一個存儲該元素的后繼在數(shù)組中的下標)

在鏈式存儲結構中,只需要一個指針(頭指針)指向第一個結點,就可以順序訪問到表中的任意一個元素。為了簡化對鏈表狀態(tài)的判定

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

頭結點的數(shù)據(jù)域可以不存儲任何信息,也可以存儲如線性表長度等類的附加信息,頭結點的指針域存儲指向第一個結點的指針(即第一個

元素結點的存儲位置)。此時,單鏈表的頭指針指向頭結點。如下圖所示:




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

納祥科技推出太陽能+Type-C雙充電自行車前燈方案,方案核心模塊包含太陽能板、單片機、三極管、3顆LED燈珠與1200mAh電池,通過低功耗單片機與三極管驅動,支持強光/弱光/爆閃3種模式,高流明遠射程,適配多種車型

關鍵字: 方案開發(fā) 電子方案 自行車前燈方案 納祥科技

慕尼黑2025年9月11日 /美通社/ -- 當?shù)貢r間9月9日,賽力斯動力在德國慕尼黑國際車展期間舉辦技術發(fā)布與交流會,正式在海外市場推出全新一代賽力斯超級增程、高效發(fā)動機和新一代分布式電驅動系統(tǒng),同時與來自全球的汽車產(chǎn)...

關鍵字: 慕尼黑 分布式 發(fā)動機 新能源汽車

慕尼黑2025年9月11日 /美通社/ -- 高端智能電動汽車品牌問界(AITO)在2025年德國國際汽車及智慧出行博覽會(IAA MOBILITY)上,正式發(fā)布了其最新全球產(chǎn)品陣容——專為中東市場深度本地化打造的AIT...

關鍵字: AI 智能駕駛 測試 生態(tài)系統(tǒng)

舍弗勒首次為中國頭部車企大規(guī)模生產(chǎn)高壓逆變磚 天津工廠一年內完成量產(chǎn)準備,逆變器模塊性能參數(shù)顯著提升 與合作伙伴羅姆半導體共研尖端碳化硅技術,效率更高、性能更優(yōu) 模塊化可擴展設計使逆變磚易于集成,可廣泛...

關鍵字: 逆變 高壓 逆變器 集成

舍弗勒以"專注驅動技術的科技公司"為主題亮相IAA MOBILITY 2025(B3館B40展臺) 合并緯湃科技后首次亮相IAA MOBILITY,展示拓展后的汽車產(chǎn)品組合 憑借在軟件、...

關鍵字: 電氣 軟件 驅動技術 BSP

拉斯維加斯2025年9月11日 /美通社/ -- 在9月8日至11日舉辦的RE+ 2025展會上,全球綜合儲能解決方案供應商德賽電池(Desay Battery)全面展示了其創(chuàng)新成果,并宣布與深圳市華寶新能源股份有限公司...

關鍵字: 電池 電芯 人工智能 鋰電

香港2025年 9月12日 /美通社/ -- 全球領先的互聯(lián)網(wǎng)社區(qū)創(chuàng)建者 - 網(wǎng)龍網(wǎng)絡控股有限公司 ("網(wǎng)龍"或"本公司",香港交易所股票代碼:777)欣然宣布,其子公司My...

關鍵字: AI 遠程控制 控制技術 BSP

慕尼黑2025年9月12日 /美通社/ -- 慕尼黑當?shù)貢r間9月10日,在2025德國國際汽車及智慧出行博覽會(IAA MOBILITY)上,國際獨立第三方檢測、檢驗和認證機...

關鍵字: 測試 慕尼黑 模型 HUBER

上海2025年9月12日 /美通社/ -- 近日,國際獨立第三方檢測、檢驗和認證機構德國萊茵TÜV大中華區(qū)(簡稱"TÜV萊茵")為上海...

關鍵字: 測試 信息安全 安全管理 開關

廣州2025年9月12日 /美通社/ -- 9月11日,由國際獨立第三方檢測、檢驗和認證機構德國萊茵TÜV大中華區(qū)(簡稱"TÜV萊茵"...

關鍵字: 數(shù)字化 供應鏈 控制 電子
關閉