2010-12-13 11 views
7

可能性の重複:それは、文字列をソートすると、プログラミングのパズルへの答えで
Plain English explanation of Big O文字列をソートするのはなぜですか(n log n)?

はO(n個のnを記録)時間がかかります。 これはどのようにして得られますか?

誰もがBig Oリソースの参照リンクを持っていますか?

おかげ

+0

「文字列の並べ替え」はどういう意味ですか?あなたは文字列のリストをソートすることを意味しますか? – jjnguy

+0

文字列内の文字を並べ替えることもできます。 –

+1

文字列内のソート文字。私はbig Oが何であるかを知っています。なぜ文字列内の文字を並べ替えるのがなぜn log nなのか分かりません。 –

答えて

10

文字列をソートするのはなぜですか(n log n)?

文字列内の文字のソートは、必ずしもO(n log n)である必要はありません。

  • Oは(N Nログ)comparison sortため最適値です。また、多くの言語のデフォルトソート実装の複雑さです。しかし、これより確実に悪いことは可能です。文字列内の文字の並べ替えの複雑さは、このタスクを解決するために選択した特定のアルゴリズムによって異なります。
  • 場合によっては、比較ソートではないソートアルゴリズムを使用することによって、O(n log n)より優れた処理を行うこともできます。たとえば、最大127文字のASCII文字列があることがわかっている場合は、O(n)のcounting sortを使用できます。カウントソートは、すべての文字がBasic Multilingual PlaneにあるUnicode文字列に対しても実行可能です。
関連する問題