Epiphany131 2022-11-12 20:04 采纳率: 78.9%
浏览 39
已结题

C语言 冒泡法对整数排序

想用冒泡法排序,但是没有实现,请问是哪里出了问题呢?


#include<stdio.h>
main()
{
    int a[10];
    for(int i=0;i<10;++i){
        scanf("%d",&a[i]);
    } 
    for(int i=0;i<9;++i){
        for(int j=1;j<10;++j){
            if(a[i]>a[j]){
                int t;
                t=a[i];
                a[i]=a[j];
                a[j]=t;
            }
        }
    }
    for(int i=0;i<10;++i){
        printf("%d,",a[i]);
    }
} 
  • 写回答

3条回答 默认 最新

  • 初阶牛 6月份城市(九江)之星TOP 1 2022-11-12 20:51
    关注

    经过一趟排序后,最后一个数已经是最大值了,不用再参与排序,将内循环次数每次减少一次就行了。
    例如:

    #include <stdio.h>
    int main()
    {
        int arr[10] = { 0 };
        for (int i = 0; i < 10; ++i) {
            scanf("%d", &arr[i]);
        }
        int i = 0;
        int sz = sizeof(arr) / sizeof(arr[0]); //计算元素的个数
        for (i = 0; i < sz; i++)//这里确定趟数,为元素个数-1躺;
        {
            int j = 0;
            for (j = 0; j < sz - i - 1; j++)//确定对数,每经过一趟就-1对,且为趟数-1;
            {
                if (arr[j] > arr[j + 1])
                {
                    int tmp = 0;
                    tmp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = tmp;
                }
            }
        }
        for (i = 0; i < sz; i++)
        {
            printf("%d ", arr[i]);//打印出数组;
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 11月21日
  • 已采纳回答 11月13日
  • 创建了问题 11月12日

悬赏问题

  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办