C语言实现快速排序
2015-09-04 15:25
691 查看
//快速排序
#include<stdio.h>
typedef int ElemType;
int Partition(ElemType A[], int left, int right)
{
ElemType pivot = A[left];
while(left < right)
{
while(left<right && A[right]>=pivot)
--right;
A[left] = A[right];
while(left<right && A[left]<=pivot)
++left;
A[right] = A[left];
}
A[left] = pivot;
return left;
}
void QuickSort(ElemType A[], int left, int right)
{
if(left < right)
{
int pivotpos = Partition(A,left,right);
QuickSort(A,left,pivotpos-1);
QuickSort(A,pivotpos+1,right);
}
}
main()
{
ElemType A[10] = {24,84,21,47,15,27,68,35,20,99};
int i;
printf("Quick Sort\n\n");
printf("array A number:");
for(i=0; i<10; i++)
printf("%d ",A[i]);
printf("\n\n");
QuickSort(A,0,9);
printf("Result:");
for(i=0; i<10; i++)
printf("%d ",A[i]);
printf("\n\n");
}
运行结果:
#include<stdio.h>
typedef int ElemType;
int Partition(ElemType A[], int left, int right)
{
ElemType pivot = A[left];
while(left < right)
{
while(left<right && A[right]>=pivot)
--right;
A[left] = A[right];
while(left<right && A[left]<=pivot)
++left;
A[right] = A[left];
}
A[left] = pivot;
return left;
}
void QuickSort(ElemType A[], int left, int right)
{
if(left < right)
{
int pivotpos = Partition(A,left,right);
QuickSort(A,left,pivotpos-1);
QuickSort(A,pivotpos+1,right);
}
}
main()
{
ElemType A[10] = {24,84,21,47,15,27,68,35,20,99};
int i;
printf("Quick Sort\n\n");
printf("array A number:");
for(i=0; i<10; i++)
printf("%d ",A[i]);
printf("\n\n");
QuickSort(A,0,9);
printf("Result:");
for(i=0; i<10; i++)
printf("%d ",A[i]);
printf("\n\n");
}
运行结果:
相关文章推荐
- 浅拷贝——C++编译器默认提供的赋值运算符
- C语言实现冒泡排序
- 什么函数不能声明或定义为虚函数
- C语言的总结
- [C++] 模板与泛型编程(2)
- 【more effective c++读书笔记】【第5章】技术(3)——要求(或禁止)对象产生于heap之中
- 【more effective c++读书笔记】【第5章】技术(3)——要求(或禁止)对象产生于heap之中
- c++ 友元类&友元函数
- C++ I/O Stream 控制小数点位数
- 浅拷贝——C++编译器默认提供的拷贝构造函数
- C++中的单例模式
- C++中的智能指针
- C语言中链表任意位置怎么插入数据?然后写入文件中?
- C语言中链表任意位置怎么插入数据?然后写入文件中?
- c语言指向函数的指针和返回指针的函数
- c++回调函数
- c++回调函数
- Larbin - C++ 实现的爬虫简介
- C语言实现快速排序
- c语言字符串与指针