快排_C实现
Posted exciting
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了快排_C实现相关的知识,希望对你有一定的参考价值。
#include<stdio.h>
int Partition(int A[], int low, int high){ int pivot; pivot = A[low]; while(low < high){ while(low < high && A[high] >= pivot)// 1.相等不替换 2.不要遗漏low < high的判断 high--; A[low] = A[high]; while(low < high && A[low] <= pivot) low++; A[high] = A[low]; } A[low] =pivot; return low; } void Qsort(int A[], int low, int high){ int pivot; if(low < high){//不要写成 while 导致死循环 pivot = Partition(A ,low, high); Qsort(A, low, pivot-1); Qsort(A, pivot+1, high); } } void QuickSort(int A[], int n){ Qsort(A, 0, n-1); } int main(){ int A[15]={5,6,4,3,2,6,4,4,6,5,3,22,6,1,-23}; QuickSort(A, 15); for(int i=0; i<15; i++) printf("%d ", A[i]); return 0; }
以上是关于快排_C实现的主要内容,如果未能解决你的问题,请参考以下文章
手撕C语言标准库qsort(自我实现简化高效版C风格泛型快排)
八大排序算法C语言过程图解+代码实现(插入,希尔,选择,堆排,冒泡,快排,归并,计数)
8种面试经典排序详解--选择,插入,希尔,冒泡,堆排,3种快排及非递归,归并及非递归,计数(图+C语言代码+时间复杂度)
8种面试经典排序详解--选择,插入,希尔,冒泡,堆排,3种快排及非递归,归并及非递归,计数(图+C语言代码+时间复杂度)