算法-快速排序

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int swap(int source[],int a,int b)
{
int temp;
temp = source[a];
source[a] = source[b];
source[b] = temp;
return 0;
}
int quicksort(int source[], int L, int R)
{
if (L < R)
{
int mid;
mid =partition(source, L, R);
quicksort(source, L, mid-1);
quicksort(source, mid+1, R);

}
}
int partition(int source[], int L, int R)
{

int less = L - 1;
int more = R;
while (L < more)
{
if (source[L] < source[R])
{
swap(source, L++, ++less);
}
else if (source[L] > source[R])
{
swap(source, L, --more);
}
else L++;
}
swap(source, more, R);
return less+1;

}
int main()
{
int source[] = { 10,16,8,9,25,26,17,93,94,3,49,31,17 };
int len;
len = sizeof(source) / sizeof(int);
quicksort(source, 0, len-1 );
for (int i = 0; i < len; i++)
{
printf("%d ", source[i]);
}
}

转载于:https://www.cnblogs.com/cyyz-le/p/11249754.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值