请大侠们解释下?

NewJerryj 2009-08-17 12:54:34

#include<iostream.h>
#include<windows.h>
#include<stdio.h>
#include <time.h>

#define NUM 100000

int Num[NUM];


void QuickSort(int left,int right,int FlagIndex)//,int SortNum[])
{

if(left<right)
{

int i=left,j=right,Flag=Num[FlagIndex];
while(i!=j)
{
while(j!=i)
{
if(Flag>Num[j])
{
Num[FlagIndex]=Num[j];
Num[j]=Flag;
FlagIndex=j;
i++;
break;
}
j--;
}

while(i!=j)
{
if(Flag<Num[i])
{
Num[FlagIndex]=Num[i];
Num[i]=Flag;
FlagIndex=i;
j--;
break;
}
i++;
}

}



QuickSort(left,i-1,left);//,SortNum);
QuickSort(i+1,right,i+1);//,SortNum);
}
return;

}



void main()
{


double dwOldTime,dwElapsed;

srand((unsigned)time(NULL));

cout<<"The random numbers are as follows:";
for(int i=0;i<NUM;i++)
{
Num[i]=rand()%100;
cout<<Num[i]<<" ";
}
cout<<endl<<endl<<endl;


dwOldTime=GetTickCount();
QuickSort(0,NUM-1,0); //,Num);
dwElapsed=GetTickCount()-dwOldTime;


cout<<"The sorted numbers are as follow:"<<endl;
for(i=0;i<NUM;i++)
cout<<Num[i]<<" ";
cout<<endl;
printf("It took %f to sort!\n",dwElapsed);

return;

}


以上代码是我写的用于测试快速排序算法的效率:随机生成N个数,放入数组,进行快速排序,显示出排序消耗的时间。
起初我使用局部变量数组Num[]来存放随机数字,发现超过100000后会有栈溢出,后来改进为使用全局数组。
但是当我把随机数的个数N设置为1000000(1百万个)时,发现运行不出结果,是不是递归深度超出最大深度的原因?
...全文
130 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
NewJerryj 2009-08-17
  • 打赏
  • 举报
回复

void test()
{
int a[1000000];
//This is a test
}
NewJerryj 2009-08-17
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 hyram 的回复:]
不知道你用的是什么环境,1000000的时候可能需要手动设置程序栈大小,有可能不够。我用codeblocks是可以的。
[/Quote]

用的VC6.0,这个除了和编译环境有关外,与系统有关吗?
xingzhe2001 2009-08-17
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 acrazer 的回复:]
可以肯定告诉你,全局数组一百万排序,肯定不会什么栈益处,
[/Quote]
全局数组当然不会溢。
楼主说"起初我使用局部变量数组Num[]来存放随机数字,发现超过100000后会有栈溢出",他把数组放在栈上,肯定没几下就溢了。
NewJerryj 2009-08-17
  • 打赏
  • 举报
回复
奇怪了,为什么我每次插入源代码都没有按照格式显示?
KWHOK 2009-08-17
  • 打赏
  • 举报
回复
可以肯定告诉你,全局数组一百万排序,肯定不会什么栈益处,

不信,你调用系统的qsort, sort试验下!

lz好好检查自己的quicksort吧
xingzhe2001 2009-08-17
  • 打赏
  • 举报
回复
是啊,栈溢出,你想你每一层递归都要申请那么大的一个数组,栈很快就消耗干了。
currenttt 2009-08-17
  • 打赏
  • 举报
回复
当NUM=1000000时,在VS2005环境下运行,会出现如下异常,即所谓的栈溢出:
Unhandled Exception at 0x004114d9....

应该是递归深度超出最大深度
hyram 2009-08-17
  • 打赏
  • 举报
回复
#include <iostream.h> 
#include <windows.h>
#include <stdio.h>
#include <time.h>

#define NUM 100000

int Num[NUM];


void QuickSort(int left,int right,int FlagIndex)//,int SortNum[])
{

if(left <right)
{

int i=left,j=right,Flag=Num[FlagIndex];
while(i!=j)
{
while(j!=i)
{
if(Flag>Num[j])
{
Num[FlagIndex]=Num[j];
Num[j]=Flag;
FlagIndex=j;
i++;
break;
}
j--;
}

while(i!=j)
{
if(Flag <Num[i])
{
Num[FlagIndex]=Num[i];
Num[i]=Flag;
FlagIndex=i;
j--;
break;
}
i++;
}

}

QuickSort(left,i-1,left);//,SortNum);
QuickSort(i+1,right,i+1);//,SortNum);
}
return;

}

void main()
{
double dwOldTime,dwElapsed;

srand((unsigned)time(NULL));

cout <<"The random numbers are as follows:";
for(int i=0;i <NUM;i++)
{
Num[i]=rand()%100;
cout <<Num[i] <<" ";
}
cout <<endl <<endl <<endl;

dwOldTime=GetTickCount();
QuickSort(0,NUM-1,0); //,Num);
dwElapsed=GetTickCount()-dwOldTime;

cout <<"The sorted numbers are as follow:" <<endl;
for(int i=0;i <NUM;i++)
cout <<Num[i] <<";
cout <<endl;
printf("It took %f to sort!\n",dwElapsed);

return;

}

不知道你用的是什么环境,1000000的时候可能需要手动设置程序栈大小,有可能不够。我用codeblocks是可以的。
LeonTown 2009-08-17
  • 打赏
  • 举报
回复
不好意思,
我总是在快排的细节上逻辑混乱。。。
NewJerryj 2009-08-17
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 leontown 的回复:]
在两个小while里面的if里,为什么还要分别i++和j--呢?
[/Quote]

分别在两边查找比flag数小和大的数时候,要向中间靠拢啊,这样才能达到i=j的状态,结束一趟排序
LeonTown 2009-08-17
  • 打赏
  • 举报
回复
在两个小while里面的if里,为什么还要分别i++和j--呢?
JAVA相关基础知识 1、面向对象的特征有哪些方面 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。 2.继承: 继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。 3.封装: 封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。 4. 多态性: 多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。 2、String是最基本的数据类型吗? 基本数据类型包括byte、int、char、long、float、double、boolean和short。 java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为了提高效率节省空间,我们应该用StringBuffer类 3、int 和 Integer 有什么区别 Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。 原始类型封装类 booleanBoolean charCharacter byteByte shortShort intInteger longLong floatFloat doubleDouble 引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。 4、String 和StringBuffer的区别 JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用StringBuffers来动态构造字符数据。 5、运行时异常与一般异常有何异同? 异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。 6、说出Servlet的生命周期,并说出Servlet和CGI的区别。 Servlet被服务器实例化后,容器运行其init方法,求到达时运行其service方法,service方法自动派遣运行与求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个求,并且其实例一般不会销毁,而CGI对每个求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。 7、说出ArrayList,Vector, LinkedList的存储性能和特性 ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。 8、EJB是基于哪些技术实现的?并说出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别。 EJB包括Session Bean、Entity Bean、Message Driven Bea

33,008

社区成员

发帖
与我相关
我的任务
社区描述
数据结构与算法相关内容讨论专区
社区管理员
  • 数据结构与算法社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧