選擇排序演算法將陣列分為兩部分:已排序部分和未排序部分。最初,已排序部分為空,未排序部分包含所有元素。此演算法的工作原理是從未排序部分中找到最小(或最大,取決於排序順序)元素,並將其與未排序部分的第一個元素交換。這個過程一直持續到整個陣列被排序為止。
#Suppose we have the following array: arr = [64, 25, 12, 22, 11]
第一遍後的陣列:[11, 25, 12, 22, 64]
第二遍後的陣列:[11, 12, 25, 22, 64]
第三遍後的陣列:[11, 12, 22, 25, 64]
最終排序數組:[11, 12, 22, 25, 64]
def selection_sort(arr): # Traverse through all array elements for i in range(len(arr)): # Find the minimum element in the remaining unsorted part min_index = i for j in range(i 1, len(arr)): if arr[j]排序數組:[11, 12, 22, 25, 64]
選擇排序的時間複雜度:
最佳情況:O(n²)
平均:O(n²)
最壞情況:O(n²)
儘管選擇排序對於小型資料集表現良好,但對於較大的陣列來說並不理想,因為它的時間複雜度為 O(n²)。然而,它很容易實現,並且在需要考慮記憶體的情況下非常有用,因為選擇排序是就地的(不需要額外的記憶體)。
優點:
易於理解和實施。
在小列表上表現良好。
不需要額外的內存,因為它對數組進行排序。
缺點:
由於其O(n²)時間複雜度,對於大型資料集效率低下。
這不是一個穩定的排序演算法,這意味著相等的元素可能無法保留它們相對於彼此的順序。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3