鱼C论坛

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

[已解决]冒泡排序

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

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

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

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

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

void bubble_sort(int array[], int length)
{
        int i, j, temp;
        
        for (i = 0; i < length - 1; i++)
        {
                for (j = 0; j < length - 1 - i; j++)
                {
                        if (array[j] > array[j+1])
                        {
                                temp = array[j];
                                array[j] = array[j + 1];
                                array[j+1] = temp;
                        }
                }
        }
}
void sort(int a[], int num)
{
        int i , j, temp;
        for(i = 0 ; i < num - 1; i++)
        {
                for(j = 0; j < num -1 -i; j++)
                {
                        if(a[j] > a[j+1]);
                        {
                                temp = a[j];
                                a[j] = a[j+1];
                                a[j+1] = temp;
                        }
                }
        }
}
int main(void)
{
        int *a, num, k = 0, i, con;
        //用户确定比较个数
        printf("请输入即将输入的整数个数:");
        if(scanf("%d",&num) != 1)
        {
                printf("数据类型输入不正确-- 程序终止!");
                exit(EXIT_FAILURE);
        }
        //开辟内存空间
        a = (int *)malloc(num * sizeof(int));
        if(a == NULL)
        {
                printf("内存空间分配失败-- 程序终止!");
                exit(EXIT_FAILURE);
        }
        //将用户输入的数据存储
        printf("输入q退出,数据输入\n");
        do
        {
                printf("正在输入第%d个数据: ",k +1);
                con =  scanf("%d",&a[k]);
                k++;
        }while(k < num  && con == 1);
        for(i = 0; i < num ;i ++)
        {
                printf("a[%d]: %d\n",i,a[i]);
        }
        //冒泡排序
        sort(a, num);
        printf("************\n");
        for(i = 0; i < num ;i ++)
        {
                printf("%d\n",a[i]);
        }
        
        bubble_sort(a, num);
        printf("************\n");
        for(i = 0; i < num ;i ++)
        {
                printf("%d\n",a[i]);
        }
        printf("当前数据中最大的元素是:%d\n",a[num - 1]);
        free(a);

        return 0;
}
最佳答案
2020-3-11 14:27:57
if(a[j] > a[j+1]);
你的代码里面这个分号很不合时宜
结果1.png
结果2.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

回帖奖励 +1 鱼币

if(a[j] > a[j+1]);
你的代码里面这个分号很不合时宜
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

哇谢谢 编译器没报错 我看了半天也没看出来 谢谢啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

其实是我的编译器提醒了我了,哈哈
我本想先编译试试看,结果一编译就提示注意了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +1 鱼币

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

领一下鱼币(虽然才 1 鱼币)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

哈哈 自己的鱼币也就十几个  账号刚升级不久.
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

哈哈 自己的鱼币也就十几个  账号刚升级不久.
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +1 鱼币

按理来说编译器应该会报错的啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +1 鱼币

领一下鱼币(虽然才 1 鱼币)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +1 鱼币

.
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 00:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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