数据结构 |
您所在的位置:网站首页 › 冒泡排序步骤 › 数据结构 |
目录 任务描述 相关知识 冒泡排序算法 编程要求 测试说明 参考代码 任务描述本关任务:实现冒泡排序算法,并将乱序数列变成升序。 相关知识为了完成本关任务,你需要掌握: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 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |