使用C++實現希爾排序算法

希爾排序是插入排序的改進版,又稱“縮小增量排序”,通過分組插入排序並逐步縮小增量實現高效排序。基本思路:選定初始增量`gap`(如數組長度的一半),按`gap`分組(子序列元素間隔`gap`),對各組子序列插入排序;重複縮小`gap`(通常減半),直至`gap=1`完成整體排序。 核心原理:大`gap`時分組減少移動次數,小`gap`時數組已部分有序,大幅降低最終插入排序的移動量。以數組`[12,34,54,2,3]`爲例,初始`gap=2`分組排序後數組漸趨有序,再`gap=1`完成最終排序。 代碼通過三層循環實現:外層控制`gap`,中層遍歷分組,內層移動元素。時間複雜度平均`O(n^1.3)`(依賴增量),最壞`O(n²)`,空間複雜度`O(1)`,不穩定。希爾排序通過分組優化插入排序,適用於較大數組,核心邏輯爲“分組→排序→縮小增量→最終排序”。

閱讀全文