#学编程的小白# 2023-08-07 22:09 采纳率: 100%
浏览 3
已结题

冒泡排序数组的输出问题

为什么我输出的数组是一串000000?


#include<stdio.h>
#include<string.h>
void maopao(int arr[], int sz) {
    for (int a = 0; a < sz - 1; a++) {
        for (int b = 0; b < sz - 1 - a; b++) {
            if (arr[b] > arr[b + 1]) {
                int temp = arr[b];
                arr[b] = arr[b + 1];
                arr[b + 1] = temp;
            }
        }
    }
}
int main()
{
    int n;
    int arr[100] = { 0 };
    while(~scanf("%d", &n)) {
        if (n == 0) {
            break;
        }
        memset(arr, 0, sizeof(arr));
        int j = 0;
        for (int i = 1; i <= n; i++) {
            int d;
            scanf("%d", &d);
            arr[j] = d;
            j++;
        }
        int sz = sizeof(arr) / sizeof(arr[0]);
        maopao(arr, sz);
        for (int c = 0; c < n; c++) {
            printf("%d ", arr[c]);
        }
        printf("\n");
    }
    return 0;
}
  • 写回答

3条回答 默认 最新

  • qzjhjxj 2023-08-07 22:15
    关注

    第18行:定义的是静态数组 int arr[100]; 它的大小已经固定了 100,所以第31行里 int sz = sizeof(arr) / sizeof(arr[0]); 得到 sz = 100,不管实际输入几个元素,经过 maopao(arr, sz); 函数调用,输入的数字元素就被排序到最末尾,所以第33行里改为for (int c = 0; c < 100; c++) 就可以看到输入的数字了。
    修改如下,可以运行下看看,供参考:

    #include<stdio.h>
    #include<string.h>
    void maopao(int arr[], int sz) {
        for (int a = 0; a < sz - 1; a++) {
            for (int b = 0; b < sz - 1 - a; b++) {
                if (arr[b] > arr[b + 1]) {
                    int temp = arr[b];
                    arr[b] = arr[b + 1];
                    arr[b + 1] = temp;
                }
            }
        }
    }
    int main()
    {
        int n;
        int arr[100] = { 0 };  //定义的数组已经是固定的元素个数:100
        while(~scanf("%d", &n)) {
            if (n == 0) {
                break;
            }
            memset(arr, 0, sizeof(arr));
            int j = 0;
            for (int i = 1; i <= n; i++) {
                int d;
                scanf("%d", &d);
                arr[j] = d;
                j++;
            }
            int sz = sizeof(arr) / sizeof(arr[0]); // 这里: sz = 100
            maopao(arr, sz);
            for (int c = 0; c < sz; c++) { //for (int c = 0; c < n; c++)
                printf("%d ", arr[c]);      //修改为输出 100 元素,就可以看到输入的元素了。
            }
            printf("\n");
        }
        return 0;
    }
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 8月25日
  • 已采纳回答 8月17日
  • 创建了问题 8月7日

悬赏问题

  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集