题目:给定一个长度为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。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .