本关任务:实现插入排序算法,并将乱序数列变成升序。
为了完成本关任务,你需要掌握:1.插入排序算法。
插入排序的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
从第一个元素开始,该元素认为已经被排序;
取下一个元素,在已经排序的元素序列中从后向前扫描;
如果已排序元素大于新元素,将已排序元素移到下一位置;
重复步骤3
,直到找到已排序的元素小于或者等于新元素的位置;
将新元素插入到该位置后;
重复步骤2
~`5`。
本关的编程任务是补全右侧代码片段sort_array
中Begin
至End
中间的代码,具体要求如下:
sort_array
中,实现插入排序算法,完成指定输出。平台将自动编译补全后的代码,并生成若干组测试数据,接着根据程序的输出判断程序是否正确。
以下是平台的测试样例:
测试输入:
10
7 1 4 6 8 9 5 2 3 10
预期输出:
1 7 4 6 8 9 5 2 3 10
1 4 7 6 8 9 5 2 3 10
1 4 6 7 8 9 5 2 3 10
1 2 3 4 5 6 7 8 9 10
测试输入:
15
3 44 38 5 47 15 36 26 27 2 46 4 19 50 48
预期输出:
3 44 38 5 47 15 36 26 27 2 46 4 19 50 48
3 38 44 5 47 15 36 26 27 2 46 4 19 50 48
3 5 38 44 47 15 36 26 27 2 46 4 19 50 48
2 3 4 5 15 19 26 27 36 38 44 46 47 48 50
//
// sort_.cpp
// Sort
//
// Created by ljpc on 2018/4/20.
// Copyright ? 2018年 ljpc. All rights reserved.
//
#include "sort_.h"
void print_array(int *arr, int n)
// 打印数组
{
if(n==0){
printf("ERROR: Array length is ZERO\n");
return;
}
printf("%d", arr[0]);
for (int i=1; i<n; i++) {
printf(" %d", arr[i]);
}
printf("\n");
}
void sort_array(int *arr, int n)
// 编程实现《插入排序算法》:将乱序序列arr转化为升序序列
// 函数参数:乱序整数数组(无重复元素) 数组长度
// 要求输出:调用print_array(int *arr, int n)输出前三次插入操作后的序列,以及最终的升序序列
{
// 请在这里补充代码,完成本关任务
/********** Begin *********/
for (int i=1; i<n; i++) {
int t = arr[i];
for (int j=i-1; j>=0; j--) {
if(t<arr[j]){
arr[j+1] = arr[j];
arr[j] = t;
}else{
break;
}
}
if(i<=3){
print_array(arr, n);
}
}
print_array(arr, n);
/********** End **********/
}