鱼C论坛

 找回密码
 立即注册
查看: 2724|回复: 4

[已解决]快速排序能用for循环吗(C语言的)

[复制链接]
发表于 2022-9-24 23:05:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
刚学习的快速排序用的while循环,尝试了下能否用for循环替换,发现水平有限,不知有哪位鱼油有空,给出个方案??
最佳答案
2022-9-25 00:02:04
本帖最后由 jackz007 于 2022-9-25 00:07 编辑
ROZE 发表于 2022-9-24 23:43
谢谢,代码已发到3楼

  1. #include <stdio.h>

  2. void quick_sort(int array[], int left, int right)
  3. {
  4.         int temp , pivot , i = left , j = right ;
  5.         pivot = array[(left + right) / 2]       ;
  6.         for(; i <= j ;) {                            // while 改 for -【1】
  7.                 //从左到右找到大于等于基准点的元素
  8.                 for(; array[i] < pivot ; i ++) ;     // while 改 for -【2】
  9.                 //从右到左找到小于等于基准点的元素
  10.                 for(; array[j] > pivot ; j --) ;     // while 改 for -【3】
  11.                 //如果i <= j,则互换
  12.                 if (i <= j) {
  13.                         temp = array[i];
  14.                         array[i] = array[j];
  15.                         array[j] = temp;
  16.                         i++;
  17.                         j--;
  18.                 }

  19.         }
  20.         if (left < j) quick_sort(array, left, j)   ;
  21.         if (i < right) quick_sort(array, i, right) ;
  22. }

  23. int main(void)
  24. {
  25.         int array[] = {73, 108, 111, 118 , 101, 70, 105, 115, 104, 67, 46, 99, 111, 109};
  26.         int i, length;

  27.         length = sizeof(array) / sizeof(array[0]) ;
  28.         quick_sort(array, 0, length-1) ;

  29.         printf("排序后的结果是:%d" , array[0])                  ;
  30.         for(i = 1 ; i < length ; i ++) printf("\t%d" , array[i]) ;
  31.         printf("\n")                                             ;
  32. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-9-24 23:30:43 From FishC Mobile | 显示全部楼层
     贴出你写的 while 循环版本,帮你改成 for 循环的版本。注意,要把代码贴进代码框内。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-24 23:42:30 | 显示全部楼层
  1. #include <stdio.h>
  2. void quick_sort(int array[], int left, int right);
  3. void quick_sort(int array[], int left, int right)
  4. {
  5.         int i = left, j = right;
  6.         int temp;
  7.         int pivot;

  8.         pivot = array[(left + right) / 2];

  9.         while (i <= j)
  10.         {
  11.                 //从左到右找到大于等于基准点的元素
  12.                 while(array[i] < pivot)
  13.                 {
  14.                         i++;
  15.         }
  16.                 //从右到左找到小于等于基准点的元素
  17.                 while (array[j] > pivot)
  18.                 {
  19.                         j--;
  20.                 }
  21.                 //如果i <= j,则互换
  22.                 if (i <= j)
  23.                 {
  24.                         temp = array[i];
  25.                         array[i] = array[j];
  26.                         array[j] = temp;
  27.                         i++;
  28.                         j--;
  29.                 }

  30.         }
  31.         if (left < j)
  32.         {
  33.                 quick_sort(array, left, j);
  34.         }
  35.         if (i < right)
  36.         {
  37.                 quick_sort(array, i, right);
  38.         }

  39. }

  40. int main(void)
  41. {
  42.         int array[] = {73, 108, 111, 118 , 101, 70, 105, 115, 104, 67, 46, 99, 111, 109};
  43.         int i, length;

  44.         length = sizeof(array) / sizeof(array[0]);
  45.         quick_sort(array, 0, length-1);

  46.         printf("排序后的结果是: ");
  47.         for (i = 0; i < length; i++)
  48.         {
  49.                 printf("%d ", array[i]);
  50.         }
  51.         putchar('\n');

  52.         return 0;
  53. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-24 23:43:17 | 显示全部楼层
jackz007 发表于 2022-9-24 23:30
贴出你写的 while 循环版本,帮你改成 for 循环的版本。注意,要把代码贴进代码框内。

谢谢,代码已发到3楼
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-25 00:02:04 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2022-9-25 00:07 编辑
ROZE 发表于 2022-9-24 23:43
谢谢,代码已发到3楼

  1. #include <stdio.h>

  2. void quick_sort(int array[], int left, int right)
  3. {
  4.         int temp , pivot , i = left , j = right ;
  5.         pivot = array[(left + right) / 2]       ;
  6.         for(; i <= j ;) {                            // while 改 for -【1】
  7.                 //从左到右找到大于等于基准点的元素
  8.                 for(; array[i] < pivot ; i ++) ;     // while 改 for -【2】
  9.                 //从右到左找到小于等于基准点的元素
  10.                 for(; array[j] > pivot ; j --) ;     // while 改 for -【3】
  11.                 //如果i <= j,则互换
  12.                 if (i <= j) {
  13.                         temp = array[i];
  14.                         array[i] = array[j];
  15.                         array[j] = temp;
  16.                         i++;
  17.                         j--;
  18.                 }

  19.         }
  20.         if (left < j) quick_sort(array, left, j)   ;
  21.         if (i < right) quick_sort(array, i, right) ;
  22. }

  23. int main(void)
  24. {
  25.         int array[] = {73, 108, 111, 118 , 101, 70, 105, 115, 104, 67, 46, 99, 111, 109};
  26.         int i, length;

  27.         length = sizeof(array) / sizeof(array[0]) ;
  28.         quick_sort(array, 0, length-1) ;

  29.         printf("排序后的结果是:%d" , array[0])                  ;
  30.         for(i = 1 ; i < length ; i ++) printf("\t%d" , array[i]) ;
  31.         printf("\n")                                             ;
  32. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-16 09:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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