标题:快速排序法,找了好久找不出错误,vc6.0编译有两个错误,求助!!
只看楼主
huangshengql
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-3-20
结帖率:71.43%
已结贴  问题点数:10 回复次数:6 
快速排序法,找了好久找不出错误,vc6.0编译有两个错误,求助!!
void PartitionQuick(int a[],int l,int h)
{
    int i,j;
    int x;
    i=l;
    j=h;
    x=a[i];
    while(i<j)
    {
        while((i<j)&&(a[j]>=x))
            j--;
        if(i<j)
        {
            a[i]=a[j];
            i++;

        }
        while((i<j)&&(a[i]<=x))
            i++;
        if(i<j)
        {
            a[j]=a[i];
            j--;
        }

    }
    a[i]=x;
   
   
}
void QuickSort(int a[],int l,int h)


{   
    int i;
   
if(l<h)
{
    i=PartitionQuick(a,l,h);
    QuickSort(a,l,i-1);
    QuickSort(a,i+1,h);
}
}
#include <stdio.h>
int main()
{
    int i;
    int a[5]={32,12,56,78,43};
    printf("排序前\n");
    for(i=0;i<5;i++)
        printf("%d\t",a[i]);
    QuickSort(a,5);
    printf("\n排序后\n");
    for(i=0;i<5;i++)
        printf("%d\t",a[i]);
    return 0;
   
}
搜索更多相关主题的帖子: void 
2013-03-31 19:38
ellisran
Rank: 1
等 级:新手上路
帖 子:10
专家分:6
注 册:2013-3-31
得分:0 
#include<stdio.h>怎么写在程序中间....
2013-03-31 22:27
huangshengql
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-3-20
得分:0 
回复 2楼 ellisran
可以写在中间
2013-04-01 22:03
蓝xuan
Rank: 4
等 级:业余侠客
帖 子:81
专家分:211
注 册:2012-3-31
得分:0 
具体是什么错误?? 指在哪个位置??
2013-04-01 22:07
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2391
专家分:13384
注 册:2013-3-3
得分:10 
i=PartitionQuick(a,l,h);这个有错误,函数是个void类型怎么能赋值呢?     QuickSort(a,5);这个参数的个数也不对,要学会看调试信息

Maybe
2013-04-01 22:20
罗庇鹏ksq
Rank: 5Rank: 5
来 自:太平洋
等 级:职业侠客
帖 子:220
专家分:310
注 册:2012-6-30
得分:0 
5楼正解

从来都是无所谓,现在也该学着有所谓。✿咱们一个人,别坐井观天❀
2013-04-01 23:03
iceberg0
Rank: 1
等 级:新手上路
帖 子:37
专家分:9
注 册:2012-3-2
得分:0 
PartitionQuick返回类型改为int,最后返回下标
2013-04-01 23:08



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-402530-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.046630 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved