鱼C论坛

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

[已解决]小甲鱼的冒泡排序代码改了参数,咋就结果不符合假设

[复制链接]
发表于 2018-11-12 20:43:11 | 显示全部楼层 |阅读模式

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

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

x
  1. #include <stdio.h>

  2. void BubbleSort(int k[], int n)
  3. {
  4.         int i, j, temp, count1=0, count2=0, flag;
  5.        
  6.         flag = 1;
  7.         for( i=0; i < n-1 && flag; i++ )
  8.         {
  9.                 for( j=n-1; j > i; j-- )
  10.                 {
  11.                         count1++;
  12.                         flag = 0;
  13.                         if( k[j-1] > k[j] )
  14.                         {
  15.                                 count2++;
  16.                                 temp = k[j-1];
  17.                                 k[j-1] = k[j];
  18.                                 k[j] = temp;
  19.                                 flag = 1;
  20.                         }
  21.                 }
  22.         }

  23.         printf("总共进行了%d次比较,进行了%d次移动!", count1, count2);
  24. }

  25. int main()
  26. {
  27.         int i, a[6] = {10,41,52,18,26,29};

  28.         BubbleSort(a, 6);

  29.         printf("排序后的结果是:");
  30.         for( i=0; i < 6; i++ )
  31.         {
  32.                 printf("%d", a[i]);
  33.         }
  34.         printf("\n\n");

  35.         return 0;
  36. }
复制代码
最佳答案
2018-11-19 10:17:27
更新flag = 0;的位置放错了,因该放在第一个for循环的下面。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-11-12 22:42:07 | 显示全部楼层
你好,下次在提问的是尽量的详细的描述你的问题吗?
比如说你改动参数,改动的什么参数?
不符合设想,你的设想是什么?这样大家才能更好的去解答你提出的问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-11-13 16:04:26 | 显示全部楼层
前路 发表于 2018-11-12 22:42
你好,下次在提问的是尽量的详细的描述你的问题吗?
比如说你改动参数,改动的什么参数?
不符合设想,你 ...

改动的是数组,不符合排好序的设想,下面是未修改的程序,可以正确运行,修改之后,无法正确运行
  1. #include <stdio.h>

  2. void BubbleSort(int k[], int n)
  3. {
  4.         int i, j, temp, count1=0, count2=0, flag;
  5.        
  6.         flag = 1;
  7.         for( i=0; i < n-1 && flag; i++ )
  8.         {
  9.                 for( j=n-1; j > i; j-- )
  10.                 {
  11.                         count1++;
  12.                         flag = 0;
  13.                         if( k[j-1] > k[j] )
  14.                         {
  15.                                 count2++;
  16.                                 temp = k[j-1];
  17.                                 k[j-1] = k[j];
  18.                                 k[j] = temp;
  19.                                 flag = 1;
  20.                         }
  21.                 }
  22.         }

  23.         printf("总共进行了%d次比较,进行了%d次移动!", count1, count2);
  24. }

  25. int main()
  26. {
  27.         int i, a[10] = {5, 2, 6, 0, 3, 9, 1, 7, 4, 8};

  28.         BubbleSort(a, 10);

  29.         printf("排序后的结果是:");
  30.         for( i=0; i < 10; i++ )
  31.         {
  32.                 printf("%d", a[i]);
  33.         }
  34.         printf("\n\n");

  35.         return 0;
  36. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-14 01:17:00 | 显示全部楼层
大可爱 发表于 2018-11-13 16:04
改动的是数组,不符合排好序的设想,下面是未修改的程序,可以正确运行,修改之后,无法正确运行

这个代码本身有漏洞,我去再找找
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-19 10:17:27 | 显示全部楼层    本楼为最佳答案   
更新flag = 0;的位置放错了,因该放在第一个for循环的下面。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-2 01:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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