イントロソートの実装をカバーする宿題の一環として、なぜマージソート(または他のアルゴリズムではなく)の代わりにヒープソートが使用されるのかを尋ねられます。
Introsortは、高速な平均パフォーマンスと(漸近的に)最適な最悪のケースのパフォーマンスの両方を提供するハイブリッドソートアルゴリズムです。クイックソートで始まり、再帰の深さがソートされる要素の数(の対数)に基づくレベルを超えると、ヒープソートに切り替わります。(ウィキペディア、2014年5月6日取得。)
私が考えることができる唯一の理由は、ヒープソートが「適所に」あるということです...しかし、これがなぜここで重要になるのかは本当にわかりません。
3
イントロソートが質問の一部である場合、私たちが何かを言う前にそれが何であるかを私たちに言わなければなりません。
—
ルイ
コンピュータサイエンスへようこそ!ここでLaTeXを使用すると、より読みやすい方法で数学をタイプセットできます。簡単な紹介はこちらをご覧ください。
—
FrankW 2014年
単純にイントロソート用の疑似コードを作成するように求められ、後でマージソートではなくヒープソートを使用する理由が尋ねられます。
—
user672009
@ user672009その場合、どちらかのコードを書き留めて、見つけたものを確認してください。理由は、パフォーマンスに関連する場合とそうでない場合があります。
—
ラファエル
私は、クイックソートが適切にソートされているため、別のインプレイスソートアルゴリズムを使用する必要があると結論付けました。しかし、私は入力のために開いています。
—
user672009 2014年