JavaScript Array.sort アルゴリズム
JavaScript Array.sort() 関数は、さまざまな引数や関数に対応した、配列の多用途な並べ替えメカニズムを提供します。 。ただし、デフォルトの並べ替えアルゴリズムは、配列要素の型によって決まります。
数値配列の場合
数値配列またはプリミティブ データ型を含む配列は、C メソッドを使用して並べ替えられます。標準ライブラリ関数 std::qsort()。この関数は、クイックソート アルゴリズムの一部のバリエーション (通常はイントロソート) で動作します。
非数値型の連続配列の場合
非数値データを含む配列は、最初に文字列化され、次に、mergesort または qsort を使用して並べ替えます。マージソートを使用すると安定したソートが保証されますが、マージソートが使用されない場合は qsort が使用されます。
他の配列タイプの場合
スパース配列として知られる、不連続な要素を含む配列、そしておそらく連想配列でも、異なる並べ替え方法が採用されています。 Chrome や Safari などのブラウザを動かす基礎となるエンジンである WebKit は、選択ソート (「最小」ソート) を採用しており、場合によっては AVL ツリーを採用しています。特定の型とアルゴリズムのマッピングは明示的に文書化されていないため、コード パスをトレースする必要があります。
将来の考慮事項
ソース コード内のコメントは、基数の実装の可能性を示唆しています。文字列値でソートされた配列のソート。時間の複雑さを改善することを目的としています。ただし、この最適化は保留中です。
以上がJavaScript の「Array.sort()」アルゴリズムは内部でどのように動作するのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。