这个问题如何解决呢?

img

img


这一句改一下试试,改成这样:int sz = (int)sizeof(arr)/sizeof(*arr);

以下是个人写的,可供题主参考:

#include <stdio.h>
//冒泡排序
void Bubble_sort(int a[], int len) 
{
        int i, j, temp;
        for (i = 0; i < len - 1; i++)
                for (j = 0; j < len - 1 - i; j++)
                        // > 为升序排序 如果是降序排序用 <
                        if (a[j] > a[j + 1]) {
                                //通过中间变量的赋值实现位置的交换
                                temp = a[j];      
                                a[j] = a[j + 1];
                                a[j + 1] = temp;
                        }
}
//主函数
int main() 
{
        int a[] = {3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};
        int len = (int)sizeof(a)/sizeof(*a);
        //调用冒泡排序函数进行排序
        Bubble_sort(a, len);
        int i;
        //循环输出排序后的结果:
        for (i = 0; i < len; i++)
            printf("%d ", a[i]);
        return 0;
}


运行结果如图:

img


自己写的文章解析:https://blog.csdn.net/qq_51646682/article/details/122307130
以上仅供参考,如有任何疑问,可以评论回复,看到即回,希望对题主有所帮助!

你可以试试加个断点调试一下

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632