vivi 快速排序 C语言实现

蔚落 2023-03-13 03:12 98阅读 0赞
  1. /*
  2. name:vivi
  3. data:2020.4.2
  4. title:quick sort
  5. */
  6. #include<stdio.h>
  7. int pos(int a[],int low,int high)
  8. {
  9. int i = low;
  10. int j = high;
  11. int temp = a[low]; //选取枢轴
  12. while(i < j)
  13. {
  14. while(i<j && temp <= a[j])
  15. j--;
  16. a[i] = a[j];
  17. while(i<j && temp >= a[i])
  18. i++;
  19. a[j] = a[i];
  20. }
  21. a[i] = temp;
  22. return i;
  23. }
  24. void quick_sort(int a[],int low,int high)
  25. {
  26. if(low<high)
  27. {
  28. int p = pos(a,low,high);
  29. quick_sort(a,low,p-1);
  30. quick_sort(a,p+1,high);
  31. }
  32. }
  33. int main()
  34. {
  35. int a[10] = {
  36. 4,0,8,1,15,2,6,11,9,3};
  37. int i;
  38. quick_sort(a,0,9);
  39. for(i = 0;i < 10;i++)
  40. printf("%d ",a[i]);
  41. return 0;
  42. }

发表评论

表情:
评论列表 (有 0 条评论,98人围观)

还没有评论,来说两句吧...

相关阅读

    相关 c语言实现快速排序

    快速排序是一种快速的排序算法。它的基本思想是,通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别

    相关 快速排序算法(C语言实现

    快速排序算法(C语言实现) 快速排序是一种基于比较的排序算法,它采用递归分治策略来排序一个序列。快速排序算法是所有基于比较的排序算法中,平均情况下表现最好的一种算法。快速排序

    相关 快速排序C语言实现

    快速排序是一种常用且高效的排序算法,它基于分治策略,通过将数组分成较小的子数组并对它们进行排序,最终将它们合并以得到排序后的数组。下面我们将介绍如何使用C语言实现快速排序,并附