找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 1019|回复: 2

关于 快速排序 的问题

[复制链接]
发表于 2009-10-31 01:21:55 | 显示全部楼层 |阅读模式 IP:江苏扬州
#include "iostream.h" void order_1(int[],int,int); void main() { int len; int a[]={12,2,13,111,14,15,1,2}; len=sizeof(a)/sizeof(int); order_1(a,0,len-1); cout<<endl<<"result is:"; for(int k=0;k<len;k++) { cout<<a[k]<<" "; } } void order_1(int a[],int left,int right) //快速排序法 { int mid,l,r,temp; l=left; r=right; mid=a[(left+right)/2]; //取中值作为分界线
while(l<r) { while(a[l]<mid) ++l; while(a[r]>mid) --r;
if(l>=r) break;
temp=a[l]; a[l]=a[r]; a[r]=temp; if(l!=mid) --r; if(r!=mid) ++l; } if(l==r) l++; if(left<r) order_1(a,left,l-1); if(l<right) order_1(a,r+1,right); }
发表于 2009-10-31 01:21:56 | 显示全部楼层 IP:江苏扬州

int a[]={12,2,13,111,14,15,1,2};
改成这些的时候
int a[]={1,1,1,1,1,1,1,1};
会出现错误 overflow stacks?
why????
回复

使用道具 举报

发表于 2009-10-31 01:21:57 | 显示全部楼层 IP:江苏扬州
// try it
#include &lt;iostream&gt;
using namespace std;

class QuickSorter
{
private:
    int * a;
    int size;
    void quicksort(int lo, int hi)
    {
        int i=lo, j=hi;
        int x=a[(lo+hi)/2];

        //  Aufteilung
        while (i&lt;=j)
        {   
            while(a[i]&lt;x)
                i++;
            while(a[j]&gt;x)
                j--;
            if(i&lt;=j)
            {
                exchange(i, j);
                i++;
                j--;
            }
        }

        // Rekursion
        if(lo&lt;j)
            quicksort(lo, j);
        if(i&lt;hi)
            quicksort(i, hi);
    }
    void exchange(int i, int j)
    {
        int t=a[i];
        a[i]=a[j];
        a[j]=t;
    }
public:
    QuickSorter(int * pi, int s)
    {
        size = s;
        a = new int[size];
        memcpy(a, pi, size * sizeof(int));
    }
    ~QuickSorter()
    {
        if(a)
        {
            delete [] a;
            size = 0;
        }
    }
    void sort()
    {
        quicksort(0, size - 1);
    }
    void display()
    {
        for(int i = 0; i&lt;size; i++)
            cout&lt;&lt;a[i]&lt;&lt;" ";
    }
};
int main()
{
    int a[] = {1,1,2,1,-6,1,1,1,1,1};
    QuickSorter myQuickSorter(a, sizeof(a)/sizeof(int));
    myQuickSorter.sort();
    myQuickSorter.display();

    return 0;
}

// viel Spass
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-29 15:33 , Processed in 0.229812 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表