c语言的快速排序,C语言实现快速排序

本文展示了如何使用C语言实现快速排序算法。代码中定义了`quik_sort`函数进行递归排序,并通过`partion`函数进行分区操作。程序首先生成一个包含15个随机数的数组,然后对其进行排序,最后输出排序前后的结果。
摘要由CSDN通过智能技术生成

#include

#include

#include

#define RANDOM(i) (rand()%i)

#define N 15

//划分函数

int partion(int a[],int p,int r){

int x = 0;

int j;

int i;

int temp;

i = p-1;

x = a[r];

for ( j = p; j <=r-1; j++)

{

if (a[j] <= x)

{

i++;

temp = a[i];

a[i] = a[j];

a[j] = temp;

}

}

temp = a[i+1];

a[i+1] = a[r];

a[r] = temp;

return i+1;

}

void quik_sort(int a[], int p,int r){

int q;

if (p < r)

{

q=partion(a,p,r);

quik_sort(a,p,q-1);

quik_sort(a,q+1,r);

}

}

void main(){

int rand_no = 0;

int i = 0;

int a[N]; //n表示数组长度

//srand((int)time(0)); //设置随机数种子

printf("==============================排序前=========================================");

printf("\\n");

for(rand_no = 0;rand_no < N;rand_no++)

{

a[rand_no]=RANDOM(100);

printf("%5d",a[rand_no]);

}

printf("\\n");

printf("==============================排序后=========================================\\n");

quik_sort(a,0,N-1);

for (int j = 0; j < N; j++)

{

printf("%5d",a[j]);

}

printf("\\n");

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值