鱼C论坛

 找回密码
 立即注册
查看: 2330|回复: 3

方法二算冒泡法吗?

[复制链接]
发表于 2022-9-8 08:29:10 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 竹逸 于 2022-9-8 15:36 编辑

方法一是小甲鱼老师写的,方法二是我自己写的,发现和课件里有一点不一样,虽然也会从小到大排列,可方法二还算冒泡法吗?

  1. #include<stdio.h>

  2. /*方法一:

  3. void main()
  4. {
  5.         int i, j, temp, a[10];
  6.         printf("please input 10 numbers:\n");

  7.         for(i=0 ; i<10 ; i++)
  8.         {
  9.                 scanf("%d", &a[i]);
  10.         }

  11.         for(i=0 ; i<9 ; i++)
  12.         {
  13.                 for(j=0 ; j<9-i ; j++)
  14.                 {
  15.                         if(a[j] > a[j+1])
  16.                         {
  17.                                 temp = a[j];
  18.                                 a[j] = a[j+1];
  19.                                 a[j+1] = temp;
  20.                         }
  21.                 }
  22.         }
  23.         for(i=0 ; i<10 ; i++)
  24.         {
  25.                 printf("%d ", a[i]);
  26.         }
  27. }
  28. */

  29. //方法二:

  30. void main()
  31. {
  32.         int i, j, temp, a[10];
  33.         printf("please input 10 numbers:\n");

  34.         for(i=0 ; i<10 ; i++)
  35.         {
  36.                 scanf("%d", &a[i]);
  37.         }

  38.         for(i=0 ; i<9 ; i++)
  39.         {
  40.                 for(j=i ; j<9 ; j++)
  41.                 {
  42.                         if(a[i] > a[j+1])
  43.                         {
  44.                                 temp = a[i];
  45.                                 a[i] = a[j+1];
  46.                                 a[j+1] = temp;
  47.                         }
  48.                 }
  49.         }

  50.         for(i=0 ; i<10 ; i++)
  51.         {
  52.                 printf("%d ", a[i]);
  53.         }
  54. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-9-8 08:42:16 | 显示全部楼层
区别是
for(j=0 ; j<9-i ; j++)

for(j=i ; j<9 ; j++)
对吧?因为前面的是排序好了,所以可以被跳过,你想少判断几次,当然算



你确定方法一是小甲鱼老师写的?
for(j=0 ; j<9-i ; j++)
有问题吧?
222222.png



小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-8 09:42:31 From FishC Mobile | 显示全部楼层
cnkizy 发表于 2022-9-8 08:42
区别是
for(j=0 ; j

你再看看我的代码,你抄错了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-8 10:08:06 From FishC Mobile | 显示全部楼层
cnkizy 发表于 2022-9-8 08:42
区别是
for(j=0 ; j

你再分别把方法一和方法二单独复制下来运行,你就知道你哪里抄错了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-16 18:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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