赞
踩
目录
本关任务:实现冒泡排序算法,并将乱序数列变成升序。
为了完成本关任务,你需要掌握:1.冒泡排序算法。
冒泡排序重复地遍历待排序的数列,每次比较两个相邻元素,如果它们的顺序错误就把它们交换。重复地进行遍历直到没有再需要交换时表示数列已经排序完成。
算法步骤:
比较相邻的元素:若第一个比第二个大,则交换;
遍历开始第一对到结尾最后一对,执行步骤1
;
重复步骤1
~2
,直到排序完成。
可改进的冒泡排序:第一趟排序之后最后一个元素是最大的,因此下一趟遍历只需执行到倒数第二对。
本关的编程任务是补全右侧代码片段sort_array
中Begin
至End
中间的代码,具体要求如下:
sort_array
中,实现冒泡排序算法,完成指定输出。平台将自动编译补全后的代码,并生成若干组测试数据,接着根据程序的输出判断程序是否正确。
以下是平台的测试样例:
测试输入:
10
7 1 4 6 8 9 5 2 3 10
预期输出:
1 4 6 7 8 5 2 3 9 10
1 4 6 7 5 2 3 8 9 10
1 4 6 5 2 3 7 8 9 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 38 5 44 15 36 26 27 2 46 4 19 47 48 50
3 5 38 15 36 26 27 2 44 4 19 46 47 48 50
3 5 15 36 26 27 2 38 4 19 44 46 47 48 50
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转化为升序序列
- // 函数参数:乱序整数数组arr 数组长度
- // 要求输出:调用print_array(int *arr, int n)输出前三次冒泡操作后的序列,以及最终的升序序列
- {
- // 请在这里补充代码,完成本关任务
- /********** Begin *********/
- int i,x,j;
- for(j=0;j<n;j++){
- for(i=0;i<n-1;i++)
- {
- if(arr[i]>arr[i+1]){
- x=arr[i];
- arr[i]=arr[i+1];
- arr[i+1]=x;
- }
- }
- if(j<3) print_array(arr,n);
- }
- print_array(arr,n);
- /********** End **********/
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。