用冒泡法排序,让一个长度为n的整型数组内数据由小到大排列。n由键盘输入,排序后将数组元素依次输出。

用冒泡法排序,让一个长度为n的整型数组内数据由小到大排列。n由键盘输入,排序后将数组元素依次输出。

问题描述:

```#include
int main(int argc, char *argv[])
{
int n,i,t;
scanf("%d\n",&n);
int a[n]={};
for(i=0;i<n;i++)
scanf("%d",&a[i]);
for(i=0;i<n;i++)
{
if(a[i+1]<a[i])
{
t=a[i];
a[i]=a[i+1];
a[i+1]=t;
}
}
for(i=0;i<n;i++)
printf("%d ",a[i]);
return 0;
图片说明
有一个错误求大佬帮助解答

你的编译器不允许变量作为初始化数组大小。你可以改成

int a[n]={};
--》
int *a = (int*)malloc(sizeof(int)*n);
然后底下改成对指针操作。

在c99中已经允许用借助scanf来实现数组的size
我改了一下,下面是我用sscanf实现的,我是新手,如有不当,谢谢指出!

#include<stdio.h>
int main(int argc, char *argv[])
{
int n,i,t;
printf("input n!");
scanf("%d",&n);
int a[n];
for(i=0;i<n;i++){
scanf("%d",&a[i]);}
for(i=0;i<n;i++)
{
if(a[i+1]<a[i])
{
t=a[i];
a[i]=a[i+1];
a[i+1]=t;
}
}
    for(i=0;i<n;i++)
    {
        printf("%d ",a[i]);
    }
    return 0;
}

希望采纳,谢谢!