QuickSort java.lang.StackOverflowError(快速排序java.lang.StackOverflow错误)
本文介绍了快速排序java.lang.StackOverflow错误的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我尝试计算在数组的中轴、第一轴、随机轴已排序三种情况下快速排序算法的执行时间。
中间枢轴和随机枢轴适用于任何大小,但如果大小大于25000,则第一个枢轴案例会产生堆栈溢出。
代码如下:
static void q_sort( int left, int right)
{
int pivot;
int l_hold, r_hold;
l_hold = left;
r_hold = right;
pivot = array[left];
while (left < right)
{
while ((array[right] >= pivot) && (left < right))
right--;
if (left != right)
{
array[left] = array[right];
left++;
}
while ((array[left] <= pivot) && (left < right))
left++;
if (left != right)
{
array[right] = array[left];
right--;
}
}
array[left] = pivot;
pivot = left;
left = l_hold;
right = r_hold;
if (left < pivot)
q_sort(left,(int) pivot-1);
if (right > pivot)
q_sort( (int)pivot+1, right);
}
调用代码如下:
double startTime1 = System.currentTimeMillis();
q_sort(0,size -1);
double stopTime1 = System.currentTimeMillis();
double elapsedTime1 = stopTime1 - startTime1;
System.out.println(elapsedTime1);
推荐答案
您没有说明数组是如何生成的,但我怀疑它已经排序。
问题如下:如果对已排序的数组进行快速排序,第一个透视会导致以下递归:0..24999、1..24999、2..24999、3..24999、4..24999,这会占用大量堆栈空间并导致堆栈溢出。这是因为数组是0..24999,轴心是0,那么第二个分区将变成1..24999。您应该删除其中一个尾部调用。要消除哪个尾部调用取决于哪个分区较小。您希望递归处理的数据尽可能少。其中一个递归被简单地替换为循环。这个尾递归消除已经在Quicksort and tail recursive optimization
中解释过了无论如何,我建议使用现有的快速排序算法,而不是自己编写代码,除非这是一个家庭作业问题。
这篇关于快速排序java.lang.StackOverflow错误的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:快速排序java.lang.StackOverflow错误


基础教程推荐
猜你喜欢
- 修改 void 函数的输入参数,然后读取 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- 存储 20 位数字的数据类型 2022-01-01
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
- Struts2 URL 无法访问 2022-01-01