冒泡排序求解?从大到小

问题遇到的现象和发生背景 冒泡排序——从大到小
用代码块功能插入代码,请勿粘贴截图

#include
void sort(int a[],int n)
{
int i,j,temp=0;
for(i=0;i<=n-1;i++)
{
for(j=0;j<=n-1-i;j++)
{
if(a[j]
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
}
int main()
{
int i,n;
printf("请输入数组个数:\n");
scanf("%d",&n);
int a[n];
printf("输入数组元素:\n");
for(i=0;i
{
scanf("%d",&a[n]);
}
printf("原始数据为:\n");
for(i=0;i
{
printf("%d",a[i]);
}
sort(a,n);
printf("\n排序后的数据为:\n");
for(i=0;i
{
printf("%d",a[i]);
}
return 0;
}

运行结果及报错内容 为什么输出的结果很奇怪?-几亿
我的解答思路和尝试过的方法 不晓得哪里错了,求解
我想要达到的结果运行结果对

1、scanf("%d",&a[n]); 里面的 &a[n] 改成 &a[i]
2、sort函数中两个for,i<=n-1 和 j<=n-1-i 改成 i<n-1 和 j<n-1-i,不要等号

img


这里有误

scanf("%d", &a[n]); 问题在这里