标题: C语言输出快速排序递归算法隐含递归树的后序遍历序列程序和示意图 [打印本页]

作者: Anza    时间: 2024-1-15 21:33
标题: C语言输出快速排序递归算法隐含递归树的后序遍历序列程序和示意图

  1. #define _CRT_SECURE_NO_WARNINGS
  2. #include<stdio.h>

  3. void QSort(int L[100], int low, int high);
  4. int Partition(int L[100], int low, int high);

  5. int main()
  6. {
  7.         int n;
  8.         int i;
  9.         int L[100] = { 0 };
  10.         scanf("%d", &n);
  11.         for (i = 1; i <= n; i++)
  12.                 scanf("%d", &L[i]);
  13.         QSort(L, 1, n);
  14.         return 0;
  15. }

  16. void QSort(int L[100], int low, int high)
  17. {
  18.     //排序的时候可以是小于,因为最后一个数不用再处理,但是要输出,
  19.     //故尽管不处理,也一定要进入if条件判断,来打印这个值,也就是一定要low <= high
  20.         if (low <= high)
  21.         {
  22.     //这里的理解和二叉树的遍历思路是一样的,也就是先打印左边的枢轴量,
  23.     //再打印右边的枢轴量,最后打印根的值
  24.                 int pivotloc = Partition(L, low, high);
  25.                 QSort(L, low, pivotloc - 1);//可以理解为打印左边的枢轴量
  26.                 QSort(L, pivotloc + 1, high);//打印右边的值
  27.                 printf("%d ", L[pivotloc]);//打印根的值
  28.         }
  29. }

  30. int Partition(int L[100], int low, int high)
  31. {
  32.         L[0] = L[low];
  33.         int pivotkey = L[low];
  34.         while (low < high)
  35.         {
  36.                 while (low < high && L[high] >= pivotkey)
  37.                         high--;
  38.                 L[low] = L[high];
  39.                 while (low < high && L[low] <= pivotkey)
  40.                         low++;
  41.                 L[high] = L[low];
  42.         }
  43.         L[low] = L[0];
  44.         return low;
  45. }
复制代码

vc++代码工程: 输出快速排序递归算法隐含递归树的后序遍历序列.7z (1.84 MB, 下载次数: 4)





欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1