[解決済み] [Solved] JavascriptのArray.sortの実装は?
2022-04-02 19:08:20
質問
JavaScriptはどのアルゴリズムで
Array#sort()
関数を使用しますか? 私は、バニラソートがどのアルゴリズムを使用しているかに興味があるだけです。
どのように解決するのですか?
WebKit (Chrome, Safari ...) を見てみたところ ソース . 配列の種類によって、異なるソート方法が使用されます。
数値配列
(またはプリミティブ型の配列) のソートには,C++ 標準ライブラリ関数
std::qsort
これは、クイックソートのいくつかのバリエーションを実装しています(通常
イントロソート
).
非数値型の連続した配列
は文字列化され、マージソート(安定したソートを得るために)があればそれを使ってソートされるか、あるいは
qsort
マージソートがない場合
その他の型(非連続配列とおそらく連想配列)については、WebKit は以下のいずれかを使用します。 選択ソート (彼らは 「最小値ソート あるいは、AVLツリーでソートする場合もあります。残念ながら、ここでのドキュメントはかなり曖昧なので、実際にどの型にどのソートメソッドが使われているかを確認するには、コードパスをトレースする必要があります。
そして、次のような逸品があります。 このコメント :
// FIXME: Since we sort by string value, a fast algorithm might be to use a
// radix sort. That would be O(N) rather than O(N log N).
- 実際にこれを「修正」する人が、このコメントを書いた人よりも漸近的実行時間についてよく理解していて、以下のことに気づいていることを祈りましょう。 基数ソートには、もう少し複雑な実行時説明があります。 単純にO(N)であるよりも。
(元の回答の誤りを指摘してくれたphsourceに感謝します)。
関連
-
[解決済み】document.getElementByIDは関数ではありません。
-
[解決済み】Uncaught ReferenceError。Reactが定義されていない
-
[解決済み】Reactのeslintエラーはpropsの検証で見つからない
-
[解決済み] JavaScriptで "use strict "は何をするのか、その根拠は?
-
[解決済み] JavaScriptで文字列が部分文字列を含むかどうかを確認する方法は?
-
[解決済み] あるJavaScriptファイルを他のJavaScriptファイルにインクルードするにはどうすればよいですか?
-
[解決済み] JavaScript で配列に値が含まれているかどうかを確認するにはどうすればよいですか?
-
[解決済み] 新しい配列を作成せずに、既存のJavaScript配列を別の配列で拡張する方法
-
[解決済み】JavaScriptの関数にデフォルトのパラメータ値を設定する
-
[解決済み】オブジェクトからプロパティを削除する(JavaScript)
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】フォームコントロールの値アクセサがない
-
[解決済み】TypeError: 'undefined'はオブジェクトではありません。
-
[解決済み】webpack: モジュールが見つかりません。Error: 解決できない(相対パスで)
-
[解決済み] [Solved] Uncaught TypeError: nullのプロパティ 'appendChild' を読み取ることができない。
-
[解決済み】PhantomJS 2.1.1を使用してReactJSアプリケーションをレンダリングできない理由とは?
-
[解決済み】Javascript、[オブジェクトHTMLInputElement]を表示中。]
-
[解決済み] JavaScriptでライブラリを使わずに配列を逆引きするには?
-
[解決済み] ソートされた数値の配列に数値を挿入する効率的な方法?
-
[解決済み] JavaScript クイックソート
-
[解決済み】インプレース基数ソート