鱼C论坛

 找回密码
 立即注册
查看: 603|回复: 2

[已解决]冒泡排序法

[复制链接]
发表于 2020-6-9 20:44:49 | 显示全部楼层 |阅读模式

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

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

x
#include<stdio.h>
int main(void)
{        int num,i,j;
        printf("请输入要排序的数字个数\n");
        scanf("%d",&num);
        int a[(num-1)];
        for(i=0;i<num;i++)
        {
                printf("a[%d]=",i);
                scanf("%d",&a[(num-1)]);
        }
       
       
        for(i=0;i<=num;i++)
        {
                for(j=(i+1);j<=num;j++)
                {
                        int temp;
                        if(a>a[j])
                        {
                                temp=a;
                                a=a[j];
                                a[j]=temp;
                        }
                }
        }
        printf("排序后是:\n");
        for(i=0;i<num;i++)
        {
                        printf("%d\t",a);
        }
       
       
        return 0;
}

大神们,这个冒泡排序法,运行出来怎么不对?运行结果如下:

请输入要排序的数字个数
6
a[0]=8
a[1]=3
a[2]=5
a[3]=1
a[4]=7
a[5]=6
排序后是:
0       6       32      4214907 4214907 1985372658
--------------------------------
Process exited with return value 0
Press any key to continue . . .

最佳答案
2020-6-9 21:04:02
很多零碎的错误。帮你修改了。
  1. #include<stdio.h>
  2. int main(void)
  3. {   int num,i,j;
  4.     printf("请输入要排序的数字个数\n");
  5.     scanf("%d",&num);
  6.     int a[num];//这里为什么要减1
  7.     for(i=0;i<num;i++)
  8.     {
  9.         printf("a[%d]=",i);
  10.         scanf("%d",&a[i]);//这里难道不应该是a[i]吗
  11.     }
  12.         
  13.         
  14.     for(i=0;i<num-1;i++)//这里应该是小于num-1
  15.     {
  16.         for(j=(i+1);j<num;j++)//这里应该是小于num
  17.         {
  18.             int temp;
  19.             if(a[i]>a[j])
  20.             {
  21.                 temp=a[i];
  22.                 a[i]=a[j];
  23.                 a[j]=temp;
  24.             }
  25.         }
  26.     }
  27.     printf("排序后是:\n");
  28.     for(i=0;i<num;i++)
  29.     {
  30.         printf("%d\t",a[i]);
  31.     }
  32.         
  33.     return 0;
  34. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-6-9 21:04:02 | 显示全部楼层    本楼为最佳答案   
很多零碎的错误。帮你修改了。
  1. #include<stdio.h>
  2. int main(void)
  3. {   int num,i,j;
  4.     printf("请输入要排序的数字个数\n");
  5.     scanf("%d",&num);
  6.     int a[num];//这里为什么要减1
  7.     for(i=0;i<num;i++)
  8.     {
  9.         printf("a[%d]=",i);
  10.         scanf("%d",&a[i]);//这里难道不应该是a[i]吗
  11.     }
  12.         
  13.         
  14.     for(i=0;i<num-1;i++)//这里应该是小于num-1
  15.     {
  16.         for(j=(i+1);j<num;j++)//这里应该是小于num
  17.         {
  18.             int temp;
  19.             if(a[i]>a[j])
  20.             {
  21.                 temp=a[i];
  22.                 a[i]=a[j];
  23.                 a[j]=temp;
  24.             }
  25.         }
  26.     }
  27.     printf("排序后是:\n");
  28.     for(i=0;i<num;i++)
  29.     {
  30.         printf("%d\t",a[i]);
  31.     }
  32.         
  33.     return 0;
  34. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-9 21:10:51 | 显示全部楼层
真不错
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-7 08:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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