[解決済み] Pythonの組み込み型sort()メソッドについて
2022-08-13 15:11:18
質問
どのようなアルゴリズムがビルトインされているのですか?
sort()
メソッドはどのようなアルゴリズムを使用していますか?そのメソッドのコードを見てもらうことは可能でしょうか?
どのように解決するのですか?
もちろんです。 コードの
はここで
で始まり、関数
islt
で始まり、かなり長い間続いています;-)。Chrisのコメントにもあるように、これはCのコードです。 また
この
のテキストファイルを読むと、テキストによる説明、結果、その他諸々がわかります。
もしあなたがCのコードよりもJavaのコードを読む方が好きなら、Joshua BlochのtimsortのJavaでの実装を見ることができます(Joshuaはまた、1997年に、Javaでまだ使われている修正mergesortを実装した人物で、Javaがいずれ彼の最近のtimsortの移植版に移行することを望むことができます)。
timsort の Java 移植版に関するいくつかの説明を以下に示します。 ここで で、その差分は こちら (必要なすべてのファイルへのポインタを含む)、キーファイルは ここに -- 参考までに、私は Java プログラマーよりも C プログラマーの方が得意ですが、この場合、Tim の C コードよりも Joshua の Java コードの方が全体的に読みやすいと思います;-)。
関連
-
[解決済み] 山積みされた靴下を効率よく組み合わせるには?
-
[解決済み] 辞書を値で並べ替えるにはどうしたらいいですか?
-
[解決済み] Pythonで辞書に新しいキーを追加するにはどうすればよいですか?
-
[解決済み] バイトを文字列に変換する
-
[解決済み] Python 3で「1000000000000000 in range(1000000000000001)」はなぜ速いのですか?
-
[解決済み】ネストされたディレクトリを安全に作成するには?
-
[解決済み】オブジェクトの配列を文字列のプロパティ値でソートする
-
[解決済み】Pythonに三項条件演算子はありますか?
-
[解決済み】2つの辞書を1つの式でマージする(辞書の和をとる)には?)
-
[解決済み] subprocess.run()の出力を抑制またはキャプチャするには?
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] 2つの線分が交差しているかどうかを確認するにはどうすればよいですか?
-
[解決済み] PythonでファイルのMD5チェックサムを計算するには?重複
-
[解決済み] Flaskで1時間ごとに関数を実行するようにスケジュールするには?
-
[解決済み] Django のテストデータベースをメモリ上だけで動作させるには?
-
[解決済み] Python 3でバイナリデータを標準出力に書き込むには?
-
[解決済み] データフレームをソートした後にインデックスを更新する
-
[解決済み] 範囲指定された浮動小数点数のランダムな配列を生成します。
-
[解決済み] Jupyter (IPython)ノートブックのセッションをpickleして保存する方法
-
[解決済み] djangoのQueryDictをPythonのDictに変更するには?
-
[解決済み] Python の sorted() はどのようなアルゴリズムを使っているのですか?重複