シェルソート
読み:シェルソート
外語:Shell's sort
挿入ソートの改良版。数列を一定間隔で分割して挿入ソートを行なう。次第に間隔を狭めていき、最後に通常の挿入ソートを行なう。これによりデータの移動量が少なくなるためソートが高速化される。
最悪計算量はO(n^2)であるが、数列の分割方法によってはO(n^1.25)程度の計算量になる。
なお、シェルソートのShellは貝殻ではなく、考案者の名前D.L.Shellに由来する。
シェルソートの手順
45 21 98 36 5 78 23 27 90 初期状態
---------------------------------------------------------------
45 36 23 数列を分割する
21 5 27
98 78 90
---------------------------------------------------------------
23 36 45 分割した数列ごとに挿入ソートを行なう
5 21 27
78 90 98
---------------------------------------------------------------
23 78 21 45 98 間隔を狭めて再び分割する
5 36 90 27
---------------------------------------------------------------
21 23 45 78 98 分割した数列ごとに挿入ソートを行なう
5 27 36 90
---------------------------------------------------------------
5 21 23 27 36 45 78 90 98 通常の挿入ソートを行なう(終わり)
再検索