Redian新闻
>
靠。Sedgewick这3w-qsort算法居然还有bug!
avatar
靠。Sedgewick这3w-qsort算法居然还有bug!# Programming - 葵花宝典
a*n
1
http://www.cs.princeton.edu/~rs/talks/QuicksortIsOptimal.pdf
第9页算法,递归前面那两行,居然把 k<=p, k>=q 给漏了!
虽然结果依然正确,且不影响主要performance,但明显是个bug嘛:)
void quicksort(Item a[], int l, int r)
{
int i = l-1, j = r, p = l-1, q = r; Item v = a[r];
if (r <= l) return;
for (;;)
{
while (a[++i] < v) ;
while (v < a[--j]) if (j == l) break;
if (i >= j) break;
exch(a[i], a[j]);
if (a[i] == v) { p++; exch(a[p], a[i]); }
if (v == a[j]) { q--; exch(a[j], a[q]); }
}
相关阅读
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。