快速排序 --递归调用一个函数初始值被写死

这次的错误在:Pattition这个函数虽然不是递归函数但是它是被递归调用的,因此最小是a[low]

我开始单纯写这个函数的时候以为是调用第一个所以数组写成了a[0]

int Pattition(int a[],int low,int high)
{
    int pivot=a[0];

#include<iostream>
using namespace std;
void QuickSort(int a[], int n);
void Qsort(int a[],int low,int high);
int Pattition(int a[],int low,int high);
void print(int a[],int low, int high);
int main()
{
    int a[]= { 3,7,2,9,6,5,8,1,4};
    cout<<"原排序为:"<<endl;
    print(a,0,8);
    QuickSort(a,9);
    system("pause");
    return 0;
}

void QuickSort(int a[], int n)
{
    Qsort(a,0,n-1);
    print(a,0,n-1);
}

void Qsort(int a[],int low,int high)
{
    int pivotloc;
    if(low < high)
    {
        pivotloc = Pattition(a,low,high);
        cout<<"pivotloc:"<<pivotloc<<"--pivot"<<a[pivotloc]<<endl; 
        cout<<"Low:"<<endl;
        print(a,low,pivotloc-1);
        cout<<"high:"<<endl;
        print(a,pivotloc+1,high);
        
        cout<<"开始递归low部分:"<<endl; 
        Qsort(a,low,pivotloc-1);
        cout<<"开始递归high部分:"<<endl; 
        Qsort(a,pivotloc+1,high);
    }
}

int Pattition(int a[],int low,int high)
{
    int pivot=a[low];
    int temp_high,temp_low; 

    while(low<high)
    {
        while(low<high&&a[high]>=pivot)
        {
            --high;
        }
        temp_high=a[low]=a[high];
        while(low<high&&a[low]<=pivot)
        {
            ++low;
        }
        temp_low=a[high]=a[low];

    }
    a[low]=pivot;
    return low;
}

void print(int a[],int low, int high)
{
    for (int i = low; i <= high; ++i)
    {
        cout<<a[i]<<" ";
    }
    cout<<endl;

}








  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值