鱼C论坛

 找回密码
 立即注册
查看: 1389|回复: 9

[已解决]冒泡排序

[复制链接]
发表于 2020-3-11 13:51:05 | 显示全部楼层 |阅读模式

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

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

x
自己写了一个冒泡排序的函数:void sort(int a[], int num)
又借用了小甲鱼的函数: void bubble_sort(int array[], int length);
代码内容一样,不过为什么结果不同呢? 搞了半天不知道为什么

  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. void bubble_sort(int array[], int length);
  4. void sort(int a[], int num);

  5. void bubble_sort(int array[], int length)
  6. {
  7.         int i, j, temp;
  8.        
  9.         for (i = 0; i < length - 1; i++)
  10.         {
  11.                 for (j = 0; j < length - 1 - i; j++)
  12.                 {
  13.                         if (array[j] > array[j+1])
  14.                         {
  15.                                 temp = array[j];
  16.                                 array[j] = array[j + 1];
  17.                                 array[j+1] = temp;
  18.                         }
  19.                 }
  20.         }
  21. }
  22. void sort(int a[], int num)
  23. {
  24.         int i , j, temp;
  25.         for(i = 0 ; i < num - 1; i++)
  26.         {
  27.                 for(j = 0; j < num -1 -i; j++)
  28.                 {
  29.                         if(a[j] > a[j+1]);
  30.                         {
  31.                                 temp = a[j];
  32.                                 a[j] = a[j+1];
  33.                                 a[j+1] = temp;
  34.                         }
  35.                 }
  36.         }
  37. }
  38. int main(void)
  39. {
  40.         int *a, num, k = 0, i, con;
  41.         //用户确定比较个数
  42.         printf("请输入即将输入的整数个数:");
  43.         if(scanf("%d",&num) != 1)
  44.         {
  45.                 printf("数据类型输入不正确-- 程序终止!");
  46.                 exit(EXIT_FAILURE);
  47.         }
  48.         //开辟内存空间
  49.         a = (int *)malloc(num * sizeof(int));
  50.         if(a == NULL)
  51.         {
  52.                 printf("内存空间分配失败-- 程序终止!");
  53.                 exit(EXIT_FAILURE);
  54.         }
  55.         //将用户输入的数据存储
  56.         printf("输入q退出,数据输入\n");
  57.         do
  58.         {
  59.                 printf("正在输入第%d个数据: ",k +1);
  60.                 con =  scanf("%d",&a[k]);
  61.                 k++;
  62.         }while(k < num  && con == 1);
  63.         for(i = 0; i < num ;i ++)
  64.         {
  65.                 printf("a[%d]: %d\n",i,a[i]);
  66.         }
  67.         //冒泡排序
  68.         sort(a, num);
  69.         printf("************\n");
  70.         for(i = 0; i < num ;i ++)
  71.         {
  72.                 printf("%d\n",a[i]);
  73.         }
  74.        
  75.         bubble_sort(a, num);
  76.         printf("************\n");
  77.         for(i = 0; i < num ;i ++)
  78.         {
  79.                 printf("%d\n",a[i]);
  80.         }
  81.         printf("当前数据中最大的元素是:%d\n",a[num - 1]);
  82.         free(a);

  83.         return 0;
  84. }
复制代码
最佳答案
2020-3-11 14:27:57
  1. if(a[j] > a[j+1]);
复制代码

你的代码里面这个分号很不合时宜
结果1.png
结果2.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-11 14:27:57 | 显示全部楼层    本楼为最佳答案   

回帖奖励 +1 鱼币

  1. if(a[j] > a[j+1]);
复制代码

你的代码里面这个分号很不合时宜
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-11 14:29:56 | 显示全部楼层
4goodworld 发表于 2020-3-11 14:27
你的代码里面这个分号很不合时宜

哇谢谢 编译器没报错 我看了半天也没看出来 谢谢啦
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-11 14:38:45 | 显示全部楼层
冷回清风暖 发表于 2020-3-11 14:29
哇谢谢 编译器没报错 我看了半天也没看出来 谢谢啦

其实是我的编译器提醒了我了,哈哈
我本想先编译试试看,结果一编译就提示注意了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-11 14:55:21 | 显示全部楼层

回帖奖励 +1 鱼币

本帖最后由 一个账号 于 2020-3-11 14:56 编辑

领一下鱼币(虽然才 1 鱼币)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-11 15:06:21 | 显示全部楼层
一个账号 发表于 2020-3-11 14:55
领一下鱼币(虽然才 1 鱼币)

哈哈 自己的鱼币也就十几个  账号刚升级不久.
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-11 15:07:03 | 显示全部楼层
whx1935 发表于 2020-3-11 14:56
领一下鱼币(虽然才 1 鱼币)

哈哈 自己的鱼币也就十几个  账号刚升级不久.
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-11 15:44:27 | 显示全部楼层

回帖奖励 +1 鱼币

按理来说编译器应该会报错的啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 01:02:33 | 显示全部楼层

回帖奖励 +1 鱼币

领一下鱼币(虽然才 1 鱼币)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 13:58:28 | 显示全部楼层

回帖奖励 +1 鱼币

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-5 10:24

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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