- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我用两种方式实现了快速排序算法。
quick_sort 函数是一样的:
void quick_sort(int *a, int left, int right) {
if (left < right) {
int mid = partition(a, left, right);
quick_sort(a, left, mid - 1);
quick_sort(a, mid + 1, right);
}
partition 函数在两个实现中是不同的:
第一种方法基于 Robert Sedgewick 的“算法”一书:
int random = rand() % (right - left + 1) + left;
exchange(&a[left], &a[random]);
int i = left;
int j = right + 1;
int pivot = a[left];
while (1) {
while (a[++i] < pivot)
if (i == right) break;
while (a[--j] > pivot)
if (j == left) break;
if (i >= j) break;
exchange(&a[i], &a[j]);
}
exchange(&a[left], &a[j]);
return j;
第二种方式基于《算法导论》一书,这种方式比第一种方式更容易理解:
int random = rand() % (right - left + 1) + left;
exchange(&a[right], &a[random]);
int pivot = a[right];
int j = left - 1;
int i;
for (i = left; i < right; i++) {
if (a[i] <= pivot) {
j++;
exchange(&a[j], &a[i]);
}
}
exchange(&a[j + 1], &a[right]);
return j + 1;
我已经在 Online Judge Site 上提交了两个实现:TSORT , 但只接受了第一个实现,第二个是 Time Limit Exceed 。存在细微差别,但我找不到导致性能差距的原因,有人可以找到并解释一下吗?
最佳答案
您的第一个是 Hoare 分区方案,而第二个是 Lomuto 分区方案。根据多个消息来源,Lomuto 的变体不应该在实践中使用,它的唯一优势是教学,因为它更容易理解。
一些这样的来源:
https://en.wikipedia.org/wiki/Quicksort
Hoare scheme is more efficient than Lomuto's partition scheme because it does three times fewer swaps on average and creates efficient partitions even when all values are equal.
https://cs.stackexchange.com/questions/11458/quicksort-partitioning-hoare-vs-lomuto
Lomuto's method is simple and easier to implement, but should not be used for implementing a library sorting method.
关于c - 以两种方式实现快速排序算法但只接受一种?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31991486/
我正在本地编程应用程序,但是当我迁移到服务器时,使用此行出现解析错误: if(!is_array($data[array_keys($data)[0]])) 返回值: Parse error: syn
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我已经开始尝试用 C++ 学习 Winsock,但我遇到了一些问题。我首先遵循 MSDN 上的 Winsock 示例(一个基本的客户端-服务器)。 http://msdn.microsoft.com/
我有一段使用 epoll 的代码,但它有问题。当我运行它时,它给出输出:服务器套接字()没问题......服务器绑定(bind)()没问题......3个4个接受:无效参数 我在 ubuntu lin
我正在寻找一种方法来接受 $_GET 变量作为文件路径,例如 - /page/test将转换为 page.php?page=test .我已经搜索过,但找不到任何可以帮助我的东西,因此我在这里问。 我
我想要一个只接受从 0 到 9 和减号的浮点数的正则表达式。 请帮忙。 最佳答案 ^[-+]?[0-9]*\.?[0-9]+$ ^ - 字符串开头 [-+]? - 0 或 1 符号指示符 [0-9]*
请问如何接受\r\n无需将其更改为 \\r\\n , 与 fgets . 我想让程序翻译 \r\n到换行符而不是将其打印为字符串。 当前代码: char buff[1024]; printf("Msg
我正在编写一个 Cocoa 应用程序,该应用程序需要在其 Dock 图标上接受已安装卷的滴落。它不是基于文档的;我打算将每个卷分派(dispatch)到 application:openFiles 中
我在 SQLite 中发现了这种意外行为。 SQLite 似乎接受 SQL 连接语法中的任意关键字。如果我不小心键入了 natural join 而不是 natural join,则会生成笛卡尔积。这
我在 Windows 窗体的同一个窗体上有一个 TreeView 和一个多行文本框。我有拖放设置,以便我可以将节点从 TreeView 拖到文本框并将文本插入文本框(这是有效的)。 我想增强这一点,以
我正在创建一棵类似于 D3 Layout Tree 的树并尝试绑定(bind)我的自定义 JSON 对象。切换树节点的代码如下。 function toggleAll(d) { if (d.c
所以,我希望能够向我的 DOB 字段发送空选项。 这是我的表单生成器: ->add('birthDate', DateType::class, array( 'widg
错误可以在这里看到:http://djaffry.selfip.com:8080/ 我希望索引页接受参数,无论是 mysite.com/search/param_here 或 mysite.com/?
我想知道标准 Scala 解析器组合器是否包含一个解析器,该解析器接受 Scala 语言本身也接受的相同标识符(如 Scala 语言规范第 1.1 节中所指定)。 StdTokenParsers 特征
我暂时使用以下行在我的 Android 手机上创建 ServerSocket: socketl = new ServerSocket(port, 0, InetAddress.getByName("1
今天早上刚刚发布了一个应用程序,我在所有可能的设备和模拟器上测试了它,但是当我从商店下载它时,应用程序在启动时崩溃。我在很多设备和iOS版本上测试过,但结果都是一样的: Incident Identi
我想要 5 个名字中最长的一个。我想我应该使用 compareTo() 方法或 length()? 输出必须是这样的: enter 5 names : Joey Mark Catherine Zach
抱歉,我不熟悉泛型,我可以创建一个如下所示的泛型类: public class InfoField { } 上面的类可以接受如下值: , User> 但是我可以有接受 map 对象作为值的类吗?
我想让一个单元格等于它上面的单元格。 当我写作时 =address(row()-1;column()) 它只是写入上面单元格的名称(例如,对于 B2,它写入 $B$1) 是否有一个函数可以输入地址并放
我正在使用Asm访问java字节码来获取方法信息。看来ClassReader类的accept方法是异步调用的,所以不可能立即获取方法信息。我该怎么办? 最佳答案 实际上,accept 方法是从您自己的
我是一名优秀的程序员,十分优秀!