1. 程式人生 > >數據結構和算法基礎知識點

數據結構和算法基礎知識點

因此 二叉查找樹 前綴樹 有向圖 刪除 決定 cal push 永遠

數據結構和算法基礎知識點

鏈表

1、鏈表是一種由節點組成的線性數據集合,每個節點通過指針指向下一個節點。它是 一種由節點組成,並能用於表示序列的數據結構。

2、單鏈表:每個節點僅指向下一個節點,最後一個節點指向空

3、雙鏈表:每個節點有兩個指針p,np指向前一個節點,n指向下一個節點,最後一個 節點指向空。

4、循環列表:每個節點指向下一個節點,最後一個節點指向第一個節點。

5、時間復雜度:索引:O(n),查找:O(n),插入:O1),刪除:O1

1、棧是一個元素集合,支持兩個基本操作:push用於將元素壓入棧,pop用於刪除棧頂元素。

2、後進先出的數據結構

3、時間復雜度:同上

隊列

1、隊列是一個元素集合,支持兩種基本操作:enqueue用於添加一個元素到隊列, dequeue用於刪除

2、先進先出的數據結構

3、時間復雜度:同上

1、樹是無向的聯通的無環圖

2、二叉樹:是一個樹形數據結構,每個節點最多可以有兩個子節點,稱為左子節點和 右子節點。

3、滿二叉樹:二叉樹中每個節點有0或者2個子節點。

4、完美二叉樹:二叉樹中每個節點有兩個子節點,並且所有的葉子節點的深度是一樣 的

5、完全二叉樹;二叉樹中除最後一層外,其他各層的節點數均達到最大值,最後一層 的節點都連續集中在最左邊。

二叉查找樹

1、是一種二叉樹,其任何節點都大於等於左子樹中的值,小於等於右子樹中的值。

2、時間復雜度:索引查找插入刪除均為Olog(n)

字典樹

1、又稱為基數樹或前綴樹,是一種用於存儲鍵值為字符串的動態集合或關聯數組的查 找樹。樹中的節點並不直接存儲關聯鍵值,而是該節點在樹中的位置決定了其關聯 鍵值,一個節點的所有子節點都有相同的前綴,根節點則是空字符串。

數狀數組

1、又稱為二進制索引樹,其概念上是樹,但以數組實現,數組中的下標代表樹中的節 點,每個節點的父節點或子節點的下標可以通過運算獲得。數組中的 每個元素都 包含了預計算的區間值之和,在整個樹更新的過程中,這些計算的值也同樣會被更 新。

2、時間復雜度:區間求和:Olog(n)),更新:Olog(n)

線段樹

1、線段樹是用於存儲區間和線段的樹形數據結構。它允許查找一個節點在若幹條線段 中出現的次數。

2、時間復雜度:同上

1、堆是一種基於樹的滿足某些特征的數據結構,整個堆中的所有父子節點的鍵值都滿 足相同的排序條件。堆分為最大堆和最小堆。在最大堆中,父節點的鍵值永遠大於 所有子節點鍵值,根節點的鍵值是最大的。最小堆中,父節點的鍵值永遠小於子節 點鍵值,根節點的鍵值是最小的。

2、時間復雜度:索引查找插入刪除:同上,刪除最大最小:O1

哈希

1、哈希用於將任意長度的數據映射到固定長度的數據。哈希函數的返回值被稱為哈希 值哈希碼或者哈希。如果不同的主鍵得到相同的哈希值,則發生了沖突。

2、Hash Maphashmap是一個存儲鍵值關系的數據結構,hash map通過哈希函數將鍵 值轉化為桶或者槽中的下標,從而便於指定值的查找。

3、沖突解決:鏈地址法:在鏈地址法中,每個桶是相互獨立的,每個索引對應一個元 素列表。處理hashmap的時間就是查找桶的時間與遍歷列表元素的時間之和。

開放地址法:在開放地址法中,當插入新值時,會判斷該值對應的哈希桶是否存在, 如果存在則根據某種算法依次選擇下一個可能的地址,直到找到一個未被占用 的地址。開放地址即某個元素的位置並不永遠由其哈希值決定。

1、圖是G=(V,E)的有序對,其包括頂點或節點的集合V以及邊或弧的集合E,其中E 括了兩個來自V的元素。

2、無向圖:圖的鄰接矩陣是對稱的,因此如果存在節點u到節點v的邊,那節點v 節點u的邊也一定存在。

3、有向圖:圖的鄰接矩陣是非對稱的,因此如果存在。。。並不一定存在。。。

數據結構和算法基礎知識點