我正在使用合并排序的实现。我正在尝试使用C++ Visual Studio2010 (msvc)。但是,当我获取一个包含300000个整数的数组进行计时时,它显示了一个未处理的堆栈溢出异常,并将我带到一个名为"chkstk.asm“的只读文件。我将大小减少到200000,它起作用了。同样,当大小为400000时,同样的代码可以与C-free 4编辑器(mingw2.95)一起工作,没有任何问题。你有什么建议让代码在Visual Studio中工作吗?
可能是合并排序中的递归导致了问题。
发布于 2010-05-15 01:29:17
我不是很确定,但这可能是您的合并排序实现的一个特殊问题(这会导致堆栈溢出)。有很多很好的实现(使用谷歌),下面是在数组大小= 2000000的VS2008上的工作。
(您可以在VS2010中尝试)
#include <cstdlib>
#include <memory.h>
// Mix two sorted tables in one and split the result into these two tables.
void Mix(int* tab1, int *tab2, int count1, int count2)
{
int i,i1,i2;
i = i1 = i2 = 0;
int * temp = (int *)malloc(sizeof(int)*(count1+count2));
while((i1<count1) && (i2<count2))
{
while((i1<count1) && (*(tab1+i1)<=*(tab2+i2)))
{
*(temp+i++) = *(tab1+i1);
i1++;
}
if (i1<count1)
{
while((i2<count2) && (*(tab2+i2)<=*(tab1+i1)))
{
*(temp+i++) = *(tab2+i2);
i2++;
}
}
}
memcpy(temp+i,tab1+i1,(count1-i1)*sizeof(int));
memcpy(tab1,temp,count1*sizeof(int));
memcpy(temp+i,tab2+i2,(count2-i2)*sizeof(int));
memcpy(tab2,temp+count1,count2*sizeof(int));
free(temp);
}
void MergeSort(int *tab,int count) {
if (count == 1) return;
MergeSort(tab, count/2);
MergeSort(tab + count/2, (count + 1) /2);
Mix(tab, tab + count / 2, count / 2, (count + 1) / 2);
}
void main() {
const size_t size = 2000000;
int* array = (int*)malloc(sizeof(int) * size);
for (int i = 0; i < size; ++i) {
array[i] = rand() % 5000;
}
MergeSort(array, size);
}
https://stackoverflow.com/questions/2836033
复制相似问题