c语言中数列排序问题

题目:给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式:
  第一行为一个整数n。
  第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式:
  输出一行,按从小到大的顺序输出排序后的数列。

出现的问题:只有输入n+1个数,才能运行出n个数的排序,请问哪里出了问题?

#include<stdio.h>
int sort(int* a, int n);
int main()
{
    int n;
    scanf("%d", &n);
    int arr[200];
    for (int i = 0; i < n; ++i)
    {
        scanf("%d ", &arr[i]);
    }
    sort(arr, n);
    for (int i = 0; i < n; ++i)
    {
        printf("%d ", arr[i]);
    }
}
int sort(int*a,int n)
{
    
    for (int k = 1; k < n; ++k)
    {
        for (int j = 0; j <=n-1-k; ++j)
        {
            if (a[j] > a[j + 1])
            {
                int temp = a[j];
                a[j] = a[j + 1];
                a[j + 1] = temp;
            }
        }
    }
}

运行界面:

5
1 5 3 2 4 6
1 2 3 4 5
D:\下载的软件\VS2022\解决方案1\x64\Debug\蓝桥杯基础练习.exe (进程 16996)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .

scanf 里面 %d 后面不要跟空格,有空格的话,就需要输入空格才算完整


#include<stdio.h>

int sort(int* a, int n);
int main()
{
    int n;
    scanf("%d", &n);
    int arr[200];

    for (int i = 0; i < n; ++i)
    {
        scanf("%d", &arr[i]);
    }

    sort(arr, n);

    for (int i = 0; i < n; ++i)
    {
        printf("%d ", arr[i]);
    }
}

int sort(int*a,int n)
{
    for (int k = 1; k < n; ++k)
    {
        for (int j = 0; j <= n-1-k; ++j)
        {
            if (a[j] > a[j + 1])
            {
                int temp = a[j];
                a[j] = a[j + 1];
                a[j + 1] = temp;
            }
        }
    }
}

运行结果为:

img