- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我们必须为自己的 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;
}
最佳答案
根据您向我们展示的代码和您对问题所在的评论,我唯一的猜测是 from
和 to
并不意味着你的想法。您的代码有 to - from
作为要排序的段的长度。如果这是准确的(而不仅仅是枢轴选择的近似值)那就意味着 to
实际上是指向要排序的区域之外的元素。这是合理的,但是 swap<Comparable*>(*pivot, *(to))
将交换列表末尾的枢轴。
关于c++ - 真正意义上的排序——Quicksort,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5772639/
我有一张 table People (First_Name, Last_Name)。此表包含与示例中一样重复的记录(并非所有行都重复): First_Name Last_Name John
我用 Java 编写过很多程序,之前也涉足过 C++。我在各种 C++ 书籍中阅读了有关指针的内容,并完成了书籍中的各种示例。 我了解指针的基础知识,但有一件事我一直不清楚。指针在现实世界中的应用是什
线 .Mappings(m => m.FluentMappings.AddFromAssemblyOf() 它有什么作用?它会在派生自 ClassMap 的 Product 类的程序集中查找任
我有用于打印数字的自定义打印功能。我制作了一个 ASCII 版本和一个 UTF-16LE 版本。 UTF-16LE 版本对 0-9 使用全角代码/字符,对十六进制使用 A-F。在调试我的函数时,我注意
这是我的代码片段: float ab(float); 以后 if(ab(temp)
我在一个项目文件中包含以下代码: //begin of the file ((window) => { 'use strict'; class View extends GSM.Event
我一直在到处寻找关于 ? 用法的正确解释。和 *。我注意到我可以使用以下方法拒绝所有用户的访问: 如果我想允许某个组,我应该在其上方添加下一行: 但是当我看到人们使用 ? 时,我开始忘记什么意思,
我正在关注 melon js tutorial .这是在我的 HUD.js 文件的顶部。 game.HUD = game.HUD || {} 我以前在其他例子中见过这个。 namespace.some
我正在处理一个包含数千行代码的文件。我正在第 700 行实现一个算法。我经常不得不离开这些行来检查文件中的其他方法。 导航回到我实际编码的地方通常很痛苦。如果我可以在第 700 行设置一个航路点并为其
我遇到了这段代码 do { if (higherQuality && w > targetWidth) { w /= 2; if (w &
uint8_t * const LCDMem = (uint8_t *) &LCDM3; 此代码在 msp430fg4618 培训套件中用于 lcd 配置。谁能解释一下上述代码的含义? 它允许使用 a
上下文 阅读一些内核代码。 问题 我不明白这行是什么意思 *(void **) &(int[2]){0,PAGE_SIZE}; 还有更多,这是什么意思 {0,PAGE_SIZE} 对我来说,它看起来不
我正在查看 Underscore.js 的源代码库,专门用于 map方法(该页面第 85 行左右,并复制到此处): _.map = function(obj, iterator, context)
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我是一名优秀的程序员,十分优秀!