原题链接:C语言训练-排序问题(2)
解题思路:
思路1、可以使用十大经典排序算法中的任意一个,本题用的是冒泡排序。题目要求从大到小输出,那么就把冒泡算法里面的两个数互换的代码改一下,就可以了,把大的数放左边,小的数放右边。
思路2、可以依旧原封不动的使用排序算法,然后在打印时,倒着打印,从最后一个开始打印。
注意事项:
这一道题真的非常有趣,就是稍微变了一下要求,本题我使用的是冒泡排序,看示例的话 用这个排序算法最慢,但是不知道后面测试用哪个示例,使用我还是用的冒泡排序
参考代码:
#include <stdio.h> void bubble_sort(int nums[],int len) { int i,j,temp; for(i = 0;i <len - 1;i++)//不用循环到最后一个元素,因为循环到倒数第二个时,就可以进行互换操作 { for(j = 0;j < len - i - 1;j++)//j < len - i - 1,是因为后面的i个元素已经排序完成了,不用重复排序了 { if(nums[j] < nums[j + 1])//如果左边的比右边的小,就把这两个数互换 { temp = nums[j]; nums[j] = nums[j + 1]; nums[j + 1] = temp; } } } } int main() { int i,nums[10]; for(i = 0;i < 10;i++) { scanf("%d",&nums[i]); } bubble_sort(nums,10); for(i = 0;i <10;i++) { printf("%d ",nums[i]); } return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复