找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 416|回复: 0
打印 上一主题 下一主题
收起左侧

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, 下载次数: 3)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏2 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表