[解決済み] 挿入ソートとバブルソートアルゴリズムの比較
2022-12-25 20:13:34
質問
いくつかのソートアルゴリズムを理解しようとしているのですが、バブルソートと挿入ソートのアルゴリズムの違いがわからず、悩んでいます。
どちらもO(n 2 )ですが、バブルソートは各パスで配列の最大値を先頭に泡立てるだけで、挿入ソートは各パスで最小値を底に沈めるだけのような気がするのですが。これらはまったく同じことをやっていますが、方向が違うのではありませんか?
挿入ソートでは、比較/ポテンシャルスワップの数はゼロから始まり、毎回増加します(つまり、0、1、2、3、4、...、n)。しかしバブルソートでは、この同じ動作が起こりますが、ソートの終わりには(つまり、n、n-1、n-2、... 0)、バブルソートはもはや最後の要素との比較が不要になるためソートが行われるため、このようになります。
しかし、このすべてについて、挿入ソートが一般的に優れているというコンセンサスがあるようです。なぜなのか、誰か教えていただけませんか?
編集 私は主に、効率や漸近的な複雑さではなく、アルゴリズムがどのように動作するかの違いに興味があります。
どのように解決するのですか?
バブルソートでは、最初の反復でn-i-1回の内部反復を行います。つまり、(0からnまでの合計) / 2で、合計(n^2) / 4となります。
これが挿入ソートがバブルソートより高速な理由です。
関連
-
[解決済み] 辞書を値で並べ替えるにはどうしたらいいですか?
-
[解決済み] 辞書のリストを辞書の値でソートするにはどうしたらいいですか?
-
[解決済み] List<T>をオブジェクトのプロパティでソートする方法
-
[解決済み] データフレームの行を複数の列でソート(並び替え)する。
-
[解決済み] 辞書をキーでソートするにはどうしたらいいですか?
-
[解決済み] 簡単な面接問題が難しくなった:1~100の数字が与えられたとき、ちょうどk個の数字が欠けていることを見つけなさい。
-
[解決済み】オブジェクトの配列を文字列のプロパティ値でソートする
-
[解決済み】固定長 6 int 配列の最速ソート
-
[解決済み】古典的なソートアルゴリズムを最新のC++で実装する方法とは?
-
[解決済み] luceneはどのように文書をインデックスするのですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】決定木(比較ソートアルゴリズム)の葉の最短の深さ)
-
[解決済み] クイックソートとヒープソートの比較
-
[解決済み] グラフにおいて最小容量が最大となる経路の探索
-
[解決済み] log(n!)=Θ(n-log(n))でしょうか?
-
[解決済み] アルゴリズム設計マニュアル』の解答はどこにあるのですか?[クローズド]
-
[解決済み] 検索語句の上位10位を見つけるアルゴリズム
-
[解決済み] クイックソートとマージソートの比較 [重複]。
-
[解決済み] 二分探索木におけるk番目の最小要素を最適な方法で探す
-
[解決済み] luceneはどのように文書をインデックスするのですか?
-
[解決済み] LR、SLR、LALRパーサーの違いは何ですか?