题目描述
void InsertSort(int a[],int n); 使用插入排序算法,将数组a的前n个元素按照升序的方式排序。
插入排序算法描述如下:
初始序列:49 38 65 97 76 13 27 49
将元素(38) 插入合适位置: [38 49] 65 97 76 13 27 49
将元素(65) 插入合适位置: [38 49 65] 97 76 13 27 49
将元素(97) 插入合适位置: [38 49 65 97] 76 13 27 49
将元素(76) 插入合适位置: [38 49 65 76 97] 13 27 49
将元素(13) 插入合适位置: [13 38 49 65 76 97] 27 49
将元素(27) 插入合适位置: [13 27 38 49 65 76 97] 49
将元素(49) 插入合适位置: [13 27 38 49 49 65 76 97]
输入与输出要求:首先输入一个整数n(1<=n<=1000),代表待排序元素的个数。然后输入n个整数,每个整数不会超过int型的存储范围。输出为n-1行,依次为1到n-1趟排序后数组内各个元素。每行输出的顺序为a[0]至a[n-1],数与数之间用空格分开,注意第n个数后没有空格而是换行符。
输入样例
8
49 38 65 97 76 13 27 49
输出样例
38 49 65 97 76 13 27 49
38 49 65 97 76 13 27 49
38 49 65 97 76 13 27 49
38 49 65 76 97 13 27 49
13 38 49 65 76 97 27 49
13 27 38 49 65 76 97 49
13 27 38 49 49 65 76 97
程序代码:
#include<stdio.h>
int main(void)
{
int num[1050] = { 0 };
int n, i, j, k;//i、j为序数,k为中间量,n为数组容量
scanf("%d", &n);
for (i = 0; i < n; i++)
{
scanf("%d", &num[i]);//读入
}
for (i = 1; i < n; i++)
{
for (j = i; j > 0; j--)//此步为排序
{
if (num[j] < num[j - 1])
{
k = num[j];
num[j] = num[j - 1];
num[j - 1] = k;
}
}
for (j = 0; j < n-1; j++)
{
printf("%d ", num[j]);
}
printf("%d\n", num[n - 1]);//输出时最后一个元素后无空格
}
return 0;
}
关键:最后一个元素后无空格