趣味演算法圖解,文科生都看懂了
編者按
IDEA 是由 SándorP. Fekete、Sebastian Morr 和 Sebastian Stiller 共同推出的圖解演算法系列。 它們最初是為 Sándor 在德國不倫瑞克工業大學開設的演算法和資料結構講座而設計的,作者希望它們能夠有更廣的用途,因此在網上釋出了這個專案,希望能夠幫助到教師、學生和有好奇心的人們。演算法將會不斷更新,可以訪問頁面瞭解更多資訊:https://idea-instructions.com/。
這些圖片使用 Inkscape 繪製,可以使用任意一款向量圖編輯軟體來編輯它們。每個演算法下面都有相應的圖片下載地址。
快速排序
快速排序是一種“分而治之”的排序演算法,通過隨機選擇“分割槽點”來避免出現最壞的情況。
Bogo 排序
Bogo 排序也被稱為“愚蠢的排序”,是一種非常簡單但低效的排序演算法,就是不斷打亂元素的順序,直到達到有序為止。
二分查詢
二分查詢是一種快速從一個有序陣列中找到某個元素位置的查詢演算法。這有點類似於猜數字遊戲,通過不斷問“目標數字是大於還是小於某個數”這樣的問題,最終猜出目標數字。
歸併排序
歸併排序也是一種“分而治之”的遞迴排序演算法。
平衡二叉樹
平衡二叉樹是自平衡的二叉樹變種,可以保證快速的查詢、插入和刪除操作。
以圖中的平衡二叉樹為例:
圖遍歷
圖遍歷演算法會遍歷圖中所有可達的頂點,可以通過輔助資料結構來實現各種遍歷,比如使用無序集合實現隨機遍歷,使用堆疊實現深度優先遍歷,使用佇列實現廣度優先遍歷。
一筆畫
一筆畫是一種 Fleury 演算法,旨在優雅地找出圖中的尤拉(Eulerian)路徑。尤拉路徑是圖中的一條路徑,剛好經過每條邊,並且每條邊只被訪問一次。
原文連結:https://idea-instructions.com/
IDEA 是由 SándorP. Fekete、Sebastian Morr 和 Sebastian Stiller 共同推出的圖解演算法系列。 它們最初是為 Sándor 在德國不倫瑞克工業大學開設的演算法和資料結構講座而設計的,作者希望它們能夠有更廣的用途,因此在網上釋出了這個專案,希望能夠幫助到教師、學生和有好奇心的人們。演算法將會不斷更新,可以訪問頁面瞭解更多資訊:https://idea-instructions.com/。
這些圖片使用 Inkscape 繪製,可以使用任意一款向量圖編輯軟體來編輯它們。每個演算法下面都有相應的圖片下載地址。
快速排序
快速排序是一種“分而治之”的排序演算法,通過隨機選擇“分割槽點”來避免出現最壞的情況。
- 隨機選擇“分割槽點”。
- 按照“分割槽點”的高度劃條線。
- 高出“分局點”的元素需要向右移動。
- 低於“分割槽點”的元素需要向左移動。
- 移動元素。
- 重複上述的步驟分別對位於“分割槽點”兩邊的元素進行排序
Bogo 排序
Bogo 排序也被稱為“愚蠢的排序”,是一種非常簡單但低效的排序演算法,就是不斷打亂元素的順序,直到達到有序為止。
- 檢視元素是否有序。
- 元素無序,那麼就打亂順序。
- 再次檢查元素是否有序。
- 如果有序,排序成功,否則繼續重複上述步驟。
二分查詢
二分查詢是一種快速從一個有序陣列中找到某個元素位置的查詢演算法。這有點類似於猜數字遊戲,通過不斷問“目標數字是大於還是小於某個數”這樣的問題,最終猜出目標數字。
- 限定元素區間。
- 待查詢元素在區間的某個位置嗎?
- 不在。
- 那麼看看待查詢元素是不是在當前位置的左邊或者右邊。
歸併排序
歸併排序也是一種“分而治之”的遞迴排序演算法。
- 把元素分成兩部分,對每一個部分採用遞迴的歸併排序。
- 比較已經排好序的元素。
- 合併已經排好序的元素。
- 排序完畢。
平衡二叉樹
平衡二叉樹是自平衡的二叉樹變種,可以保證快速的查詢、插入和刪除操作。
以圖中的平衡二叉樹為例:
- 左子節點比父節點小,而父節點比右子節點小。如果根節點左右子樹的高度差超過 1,就變得不平衡。
- 想知道樹中是否包含了元素 11?11 比 10 大,那麼就查詢 10 的右子節點 12。11 比 12 小,所以就查詢 12 的左子節點,12 的左子節點剛好是要查詢的 11。同樣的,樹中是否包含了元素 8?8 比 10 小,那麼就查詢 10 的左子節點 6。8 比 6 大,那麼就查詢 6 的右子節點。6 的右子節點不存在,說明樹中不存在元素 8。
- 如何找到樹中最小的元素?從根節點開始,一直順著左子節點,找到最後一個葉子節點就是樹中最小的元素。
- 如何找到 10 的下一個元素?如果根節點剛好是 10,那麼就從 10 的右子樹中找到最小的那個元素。如果根節點不是 10,那麼先找到 10,如果 10 沒有右子節點,那麼就一直往父節點找,直到找到比 10 大的元素為止。
- 在樹種加入 17 或刪除 10,破壞了樹的平衡,這個時候需要通過旋轉恢復樹的平衡。
圖遍歷
圖遍歷演算法會遍歷圖中所有可達的頂點,可以通過輔助資料結構來實現各種遍歷,比如使用無序集合實現隨機遍歷,使用堆疊實現深度優先遍歷,使用佇列實現廣度優先遍歷。
- 隨機查詢:選定一個頂點,把它放入一個無序集合中。從集合中取出一個頂點,訪問該頂點,把該頂點的相鄰頂點放入集合中,並把該頂點移出集合。重複這一過程,直到集合中的元素全部被遍歷完畢。
- 深度優先遍歷:選定一個頂點壓入棧中,把該頂點其中的一個相鄰頂點也壓入棧中。訪問棧頂的頂點,如果該頂點沒有其他相鄰的頂點,就出棧。如果有其他相鄰頂點,就把其中的一個相鄰頂點壓入棧中。重複這一過程,直到棧中的元素全部被遍歷完畢。
- 廣度優先遍歷:選定一個頂點,把該頂點的相鄰頂點放進佇列尾部。訪問佇列頭部的頂點,把該頂點移出佇列,如果該頂點有相鄰頂點,就把相鄰頂點放進佇列尾部。重複這一過程,直到佇列中的元素全部遍歷完畢。
一筆畫
一筆畫是一種 Fleury 演算法,旨在優雅地找出圖中的尤拉(Eulerian)路徑。尤拉路徑是圖中的一條路徑,剛好經過每條邊,並且每條邊只被訪問一次。
- 頂點度數表示該頂點有幾條邊。
- 如果圖中有且僅有兩個頂點的度數為奇數,其他為偶數,或者不存在奇數度數的頂點,則存在尤拉路徑。
- 選定一個頂點開始畫路徑。
- 如果存在兩個以上的橋,那麼可以走橋。如果只剩下一個橋,就不能走橋,除非只剩下橋可以走。
- 如果還有沒有走過的邊,重複步驟 4。
- 成功畫出尤拉路徑。
原文連結:https://idea-instructions.com/
來自: InfoQ
相關文章
- CAS-一看就懂了點
- 前端都該懂的瀏覽器工作原理,你懂了嗎?前端瀏覽器
- 手撕redis分散式鎖,隔壁張小帥都看懂了!Redis分散式
- PHP 經典趣味演算法 (學習函式)PHP演算法函式
- 圖解排序演算法圖解排序演算法
- 演算法(八):圖解KNN演算法演算法圖解KNN
- 懂了!國際演算法體系對稱演算法DES原理演算法
- 《演算法圖解》筆記演算法圖解筆記
- 圖解JavaScript演算法排序圖解JavaScript演算法排序
- 圖解堆排序演算法圖解排序演算法
- Ckeditor 缺少影像原始檔地址的解決 笨笨的人都看啦!
- 演算法(六):圖解貪婪演算法演算法圖解
- 不會SQL隱碼攻擊,連漫畫都看不懂了SQL
- 圖解一致性雜湊演算法,看這一篇就夠了!圖解演算法
- 美顏sdk趣味拍攝功能會用到哪些演算法?演算法
- 趣味練習:用迴圈語句做出圖形
- win10看圖慢怎麼辦 win10看圖太卡怎麼解決Win10
- 圖解Golang的GC演算法圖解GolangGC演算法
- 演算法圖解之快速排序演算法圖解排序
- 【演算法】演算法圖解筆記_快速排序演算法圖解筆記排序
- Python五種常見的演算法,你都瞭解麼Python演算法
- JS垃圾回收,這次可以看懂了(帶圖警告)JS
- 非對稱加密與安全證書看這一篇就懂了加密
- 演算法(五):圖解貝爾曼-福特演算法演算法圖解
- 圖解抖音推薦演算法圖解演算法
- 《演算法圖解》學習記錄演算法圖解
- 演算法(四):圖解狄克斯特拉演算法演算法圖解
- 文科生如何高效學資料科學?資料科學
- 演算法(七):圖解動態規劃演算法圖解動態規劃
- 「排序演算法」圖解雙軸快排排序演算法圖解
- 圖解Dijkstra演算法+程式碼實現圖解演算法
- 圖解 ECDHE 金鑰交換演算法圖解演算法
- 【乾貨】趣味詳解 3 種 Python 執行緒鎖Python執行緒
- 圖解機器學習 | 降維演算法詳解圖解機器學習演算法
- 看圖學HTTPSHTTP
- 透過現象看本質,圖解支援向量機圖解
- 你看,搞技術的上班都幹啥?
- 演算法(三):圖解廣度優先搜尋演算法演算法圖解