快乐打码 2023-02-15 14:23 采纳率: 70.6%
浏览 38
已结题

请问我这样写是出现了什么问题为什么会出这样的错误

冒泡排序

在一组给定的20个数据中{5,9,8,16,3,25,78,34,6,47,33,22,19,57,83,98,65,62,7,59},(该数据不可更改,可复制进程序的数组初始化中),请用冒泡方法按从小到大排序。输出每趟的排序结果(共19趟数据),以检验是否为冒泡排序。

输入格式:

输出格式:
5 8 9 3 16 25 34 6 47 33 22 19 57 78 83 65 62 7 59 98
5 8 3 9 16 25 6 34 33 22 19 47 57 78 65 62 7 59 83 98
5 3 8 9 16 6 25 33 22 19 34 47 57 65 62 7 59 78 83 98

3 5 6 7 8 9 16 19 22 25 33 34 47 57 59 62 65 78 83 98

输入样例:
无输入。

输出样例:
下面给出了前3趟和最后一趟的样例,测试时如前3行数据正确(格式不重要)即可提交查看结果是否正确。(请给出一共19行排序的过程数据)

5 8 9 3 16 25 34 6 47 33 22 19 57 78 83 65 62 7 59 98
5 8 3 9 16 25 6 34 33 22 19 47 57 78 65 62 7 59 83 98
5 3 8 9 16 6 25 33 22 19 34 47 57 65 62 7 59 78 83 98

3 5 6 7 8 9 16 19 22 25 33 34 47 57 59 62 65 78 83 98

#include<stdio.h>
int main(){
    int t=0;
    int a[29]={5,9,8,16,3,25,78,34,6,47,33,22,19,57,83,98,65,62,7,59};
    for(int i=0;i<=20;i++){
        for(int j=1;j<20;j++){
            if(a[j]>a[j+1]){
                t=a[j];
                a[j]=a[j+1];
                a[j+1]=t;
            } 
            if(i<3){
            if(j==19)
            printf("%d\n",a[j]);
            else
                printf("%d ",a[j]);
            }
        }
    }
    printf("...\n");
    for(int i=1;i<=20;i++){
        if(i==20)
            printf("%d",a[i]);
        else
            printf("%d ",a[i]);
    }
}


  • 写回答

3条回答 默认 最新

  • 快乐鹦鹉 2023-02-15 14:26
    关注

    总共20个元素,你排序用

    
    #include<stdio.h>
    int main(){
        int t=0;
        int a[20]={5,9,8,16,3,25,78,34,6,47,33,22,19,57,83,98,65,62,7,59};
       for(int i=0;i<19;i++)
       {
          for(int j=0;j<19-i;j++)
          {
                if(a[j]>a[j+1]){
                    t=a[j];
                    a[j]=a[j+1];
                    a[j+1]=t;
                } 
           }
           if(i<3)
           {
           for(int j=0;j<20;j++)
           {
                if(j==0)
                     printf("%d",a[j]);
                else
                    printf(" %d",a[j]);
           }
           printf("\n");
          }
        }
        for(int j=0;j<20;j++)
           {
                if(j==0)
                     printf("%d",a[j]);
                else
                    printf(" %d",a[j]);
           }
    }
     
     
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月23日
  • 已采纳回答 2月15日
  • 创建了问题 2月15日

悬赏问题

  • ¥15 暴雪战网api相关问题
  • ¥15 而使用UE5引擎的 工具选项里 打开c++ visual studio 就会有部分显示加载失败 如图 加载失败的这张图 请问是什么原因
  • ¥15 mysql 对多个字段模糊查询,返回第一个匹配的字段
  • ¥15 the testing results of the whole dataset is empty
  • ¥15 can问题,往哥解决
  • ¥15 FFmpeg 成功推流到 Nginx RTMP 服务器但无法用 ffplay 或 VLC 播放
  • ¥15 请修改以下C语言代码使其能正确输出最短路径
  • ¥20 抖音商城拉码器安卓报错求解决办法或者有新的拉码脚本也可以介绍一下
  • ¥15 MPLAB IDE V2.35 报错make[2]: *** [build/default/production/_ext/1472/MSSP_I2C.p1] Error 1
  • ¥15 在国外文献网站里点击view pdf 加载异常缓慢甚至加载不出来。