开发者

Quicksort Pivot Points

开发者 https://www.devze.com 2023-03-02 14:55 出处:网络
For quicksort, (in java, if it matters), is there a relationship between the number of pivot points (or pivot ind开发者_JS百科ices) and the size of a given array? For example, if the array size is 10,

For quicksort, (in java, if it matters), is there a relationship between the number of pivot points (or pivot ind开发者_JS百科ices) and the size of a given array? For example, if the array size is 10, are there always going to be, say, 5 pivot points?


Yes, about n/2 is correct. However, I don't know why it would matter.


Not necessarily. It depends on the data and your algorithm. On average with decently random data and a decent implementation it should be on the order of log2(n) pivots.


You could have how ever many pivots you want (up to n I suppose...)

The more pivots you have, the more efficient the next recursion will be, although if it were too large (especially if it were non-constant) you would lose more time finding your pivot than you would gain.

I believe the typical is 3 potential pivots per iteration, but it's entirely dependent on implementation.

But remember that in the worst case, you're going to end up with n iterations (quicksort's worst case is O(n^2)). That would naturally lend itself to requiring n pivots, and each iteration would do very little work.

Now, on the last iteration, you can expect about n/3 pivots. On the iteration above that, it would be n/6. On the next iteration it would be n/12. If you take the limit of that series, you end up with .6 repeating. So it looks like you can expect 2/3 n total pivots (because you'd have about 2/3 n total iterations)

0

精彩评论

暂无评论...
验证码 换一张
取 消