--- tags: 資料結構筆記 --- # 資料結構:性能與漸進符號 ## 介紹 在程式設計中,選擇正確的資料結構是非常重要的。我們需要了解資料結構的性能以及如何使用漸進符號來描述它們。這對於開發高效率的程式至關重要。 ## 演算法效能分析 - 名詞解釋 在學習資料結構之前,我們先來了解一下演算法效能分析的基本概念。 ### 效能分析 Performance analysis **效能分析**是用來評估演算法執行效率的一種方法。它可以幫助我們了解演算法在不同輸入大小下的執行時間和空間需求。 ### 時間複雜度 Time complexity **時間複雜度**是指演算法執行所需的時間。它可以用來比較不同演算法的效率。 ### 空間複雜度 Space complexity **空間複雜度**是指演算法執行所需的空間。它可以用來評估演算法在記憶體上的使用情況。 ### 漸近符號 Asymptotic notation **漸近符號**是用來表示函數的成長速度的一種符號。它可以用來比較不同函數的成長速度。 ### Big Oh 符號 Big Oh notation **Big Oh 符號**是一種常用的漸近符號。它表示函數在某個輸入大小之後,與另一個函數的差異可以忽略不計。 ## Array vs. Linked List ### 陣列 Array - 用來表示有序串列的一種資料結構。 - **特質** 1. 使用連續MEM空間 2. 放置相同資料型態元素之串列 3. 使用前需宣告陣列大小 => 不彈性 4. 可以連續存取、隨機存取 - **優點**: - 可以直接訪問特定位置的資料,速度快。 - 不需要額外的連結欄位,節省了空間。 - **缺點**: - 插入或刪除元素時可能需要移動大量資料,效率較低。 - 大小固定,無法動態調整。 ### 鏈結串列 Linked List - **優點**: - 容易插入或刪除元素,只需調整連結關係。 - 不需要提前分配固定大小的空間。 - **缺點**: - 查找元素需要遍歷整個串列,效率較低。 - 需要額外的連結欄位。 ## 性能的重要性 選擇正確的資料結構可以極大地影響程式的效能。例如,如果你需要快速查找特定元素,那麼 Array 可能是一個更好的選擇。如果你需要經常插入或刪除元素,那麼 Linked List 可能更適合。 ## 漸進符號 漸進符號用於描述算法的時間複雜度。以下是一些常見的漸進符號: - **O(1)**:常數(constant)時間。無論輸入多大,操作時間都是固定的。 - **O(log n)**:對數(logarithmic)時間。例如,二分搜索算法。 - **O(n)**:線性(linear)時間。隨著輸入增長,操作時間也成比例增長。 - **O(n^2)**:平方(quadratic)時間。通常與巢狀迴圈相關,如簡單的選擇排序。 - **O(n^3)**:立方(cubic)時間。當一個算法的時間複雜度為 $O(n^3)$ 時,這表示在最壞情況下,隨著輸入規模的增長,該算法的執行時間將以輸入規模的立方倍數增長。 - **O(n!)**:階乘(factorial)時間。通常用於具有極高時間複雜度的算法。 ## 如何選擇正確的資料結構? 根據你的應用需求,選擇適當的資料結構非常重要。下面是一些建議: - 如果你的應用需要快速查找特定元素,可以考慮使用 Array。 - 如果你的應用需要經常插入或刪除元素,特別是在序列中間,那麼 Linked List 可能是一個更好的選擇。 - 如果你不確定哪種資料結構更適合,可以考慮進行一些基本的性能測試,以便做出更好的選擇。 ## 總結 了解資料結構的性能以及如何使用漸進符號來描述它們,是設計高效率程式的重要一環。根據你的應用需求,選擇適當的資料結構,可以使你的程式更有效率。 ## 備注 - **g(n)** 是 f(n) 的最高次項。 - **C** 是 f(n) 在n趨於無窮大時的常數項。 - **Big Oh** 複雜度是一種用來估計函數運算時間的簡單方法。
×
Sign in
Email
Password
Forgot password
or
By clicking below, you agree to our
terms of service
.
Sign in via Facebook
Sign in via Twitter
Sign in via GitHub
Sign in via Dropbox
Sign in with Wallet
Wallet (
)
Connect another wallet
New to HackMD?
Sign up