QuickSort/快速排序/快排

#include <stdio.h>
#include <time.h>
#include <getopt.h>
#include <stdlib.h>

void exchange(int *array,int i1,int i2)
{
        int temp;
        temp=array[i1];
        array[i1]=array[i2];
        array[i2]=temp;
}

int partition(int *array,int begin,int end)
{
        int pivot_index;
        int pivot;
        int i,j;
        srand(time(NULL));
        pivot_index=rand()%(end-begin+1)+begin;
        exchange(array,pivot_index,end);
        pivot_index=end;
        pivot=array[pivot_index];
        j=begin-1;
        for(i=begin;i<end;i++)
        {
                if(array[i]<pivot)
                {
                        j++;
                        exchange(array,i,j);
                }
        }
        exchange(array,j+1,pivot_index);
        return j+1;
}

void quicksort(int *array,int begin,int end)
{
        int pa;
        if(begin<end)
        {
                pa=partition(array,begin,end);
                quicksort(array,begin,pa-1);
                quicksort(array,pa+1,end);
        }
}

int main(int argc,char *argv[])
{
        int op;
        int num;
        int i;
        FILE *fp_input=stdin;
        FILE *fp_output=stdout;
        int *array;
        while((op=getopt(argc,argv,":i:o:"))!=-1)
        {
                switch(op)
                {
                        case 'i':
                                fp_input=fopen(optarg,"r");
                                if (fp_input==NULL)
                                {
                                        fprintf(stderr,"open file %s fail!",optarg);
                                        return 1;
                                }
                                break;
                        case 'o':
                                fp_output=fopen(optarg,"w");
                                if(fp_output==NULL)
                                {
                                        fprintf(stderr,"open file %s fail!!",optarg);
                                        return 1;
                                }
                                break;
                        case ':':
                                fprintf(stderr,"option needs a value\n");
                                break;
                        case '?':
                                fprintf(stderr,"unknow option: %c\n",optopt);
                                break;

                }
        }
        fscanf(fp_input,"%d",&num);
        array=(int *)malloc(num*sizeof(int));
        if (array==NULL)
        {
                fprintf(stderr,"out of space!!!\n");
                return 2;
        }

        for(i=0;i<num;i++)
        {
                fscanf(fp_input,"%d",array+i);
        }

        quicksort(array,0,num-1);

        for(i=0;i<num;i++)
        {
                fprintf(fp_output,"%d",*(array+i));
        }
        fprintf(fp_output,"\n");
        free(array);
        fclose(fp_input);
        fclose(fp_output);
        return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值