免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1579 | 回复: 4
打印 上一主题 下一主题

自己实现的qsort 出现段错误,请大家帮忙看看。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-03-12 10:15 |只看该作者 |倒序浏览

  1. #include <cstdio>

  2. void swap(int & a, int &b)
  3. {
  4.         int t = a;
  5.         a = b;
  6.         b = t;
  7. }

  8. void quicksort(int data[], int first, int last)
  9. {
  10.         int lower = first+1;
  11.         int upper = last;
  12.         swap(data[first], data[(first+last)/2]);
  13.         int bound = data[first];
  14.         while(lower <= upper)
  15.         {
  16.                 while(data[lower]<bound)
  17.                         lower--;
  18.                 while(bound < data[upper])
  19.                         upper++;
  20.                 if (lower < upper)
  21.                         swap(data[lower++], data[upper--]);
  22.                 else
  23.                         lower++;
  24.         }
  25.         swap(data[upper], data[first]);
  26.         if (first < upper-1)
  27.                 quicksort(data, first, upper-1);
  28.         if (upper+1 < last)
  29.                 quicksort(data, upper+1, last);
  30. }

  31. void quicksort(int data[],int n)
  32. {
  33.         if (n < 2)
  34.                 return;
  35.         int max_ =0 ;               
  36.         for (int i=0; i<n; i++)
  37.         {
  38.                 if (data[max_]<data[i])
  39.                         max_ = i;
  40.         }
  41.         swap(data[n-1], data[max_]);
  42.         quicksort(data, 0, n-2);
  43. }

  44. int main(int argc, char*argv[])
  45. {
  46.         int a[]={4, 6, 1, 7, 3, 0, 5};
  47.        
  48.         quicksort(a, 7);
  49.         return 0;
  50. }

复制代码

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
2 [报告]
发表于 2007-03-12 10:30 |只看该作者
while(bound < data[upper])
       upper++;

这句会导致数组越界吧?
我不知道这个算法是不是你独创的,
我很难看懂。

论坛徽章:
0
3 [报告]
发表于 2007-03-12 10:37 |只看该作者
原帖由 lenovo 于 2007-3-12 10:30 发表
while(bound < data[upper])
       upper++;

这句会导致数组越界吧?
我不知道这个算法是不是你独创的,
我很难看懂。


这是我根据数据结构上快速排序的伪代码自己实现的。

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
4 [报告]
发表于 2007-03-12 10:58 |只看该作者
原帖由 fannyth 于 2007-3-12 10:37 发表


这是我根据数据结构上快速排序的伪代码自己实现的。

我给你指出错误了,
结果你说你根据伪码自己实现的,
你还让我怎么说呢?

论坛徽章:
0
5 [报告]
发表于 2007-03-12 12:31 |只看该作者
楼主还是用gdb调试一下吧,呵呵,数据结构的练习题~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP