c++ - 真正意义上的排序——Quicksort

标签 c++ quicksort

我们必须为自己的 Comparable 基类做一个优化的快速排序。对于我的生活,我无法让它发挥作用。该算法看起来很简单,但是我看不到让我的代码工作。我有一个 DateTime 类,它扩展了我用来测试的 Comparable 并且排序似乎有效,但是每 20 次左右就有一次运行单个值是不合适的,当我对较少的数组 block 使用插入排序时超过 8 整个排序就会乱七八糟。

在我的分区方法中,当我将枢轴移动到末尾并在开始和结束处开始我的指针 - 1 时,它会起作用。我想将枢轴移动到末尾 - 1,因为第一个和最后一个已经排序并且首先从 + 1 开始指针,然后从 -2 结束,但如果我尝试这样做,一切都会崩溃,但我不明白为什么。

所以我现在有一些东西可以用了。当我不在较小的子数组上使用插入排序时,它会有点痉挛,这很麻烦,但最终我会弄清楚。感谢 ben j 指出关于数组的掉落......这导致了插入排序问题。 :)

我当前的代码如下

    Comparable** partition(Comparable** from, Comparable** to)
{
    Comparable** pivot  = from + (to - from) / 2;
    SortFirstMiddleLast(from, pivot, to - 1);
    swap(*pivot, *to);
    pivot = to;
    ++from; to -= 2;
    while (from <= to)
    {
        while (**from <= **pivot && from <= to) ++from;
        while (**to   >= **pivot && from <= to) --to;
        if (from < to)
        {
            swap(*from, *to);
            ++from; --to;
        }
    }
    swap(*from, *pivot);
    return from;
}

最佳答案

根据您向我们展示的代码和您对问题所在的评论,我唯一的猜测是 fromto并不意味着你的想法。您的代码有 to - from作为要排序的段的长度。如果这是准确的(而不仅仅是枢轴选择的近似值)那就意味着 to实际上是指向要排序的区域之外的元素。这是合理的,但是 swap<Comparable*>(*pivot, *(to))将交换列表末尾的枢轴。

关于c++ - 真正意义上的排序——Quicksort,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5772639/

相关文章:

c++ - 提升文件系统,需要帮助理解我在做什么

delphi - 快速排序戏剧

java - 如何对原始数据类型数组调用java内置TimSort

vba - VBA中的快速排序不忽略字母的大小写

java - 为什么 QuickSort 比 BubbleSort 慢这么多?

c - 双链表随机快速排序

c++ - 尝试制作一个 while 循环,减去一个数字直到达到所需值,如果减法超过所需值,则显示并停止

c++ - cpp 的函数式方法

c++ - GLUT 显示部分桌面而不是我的代码中的内容

c++ - io_service.run() 没有阻塞。服务器已创建,然后立即关闭