题目描述:
用选择法对10个整数从小到大排序。
输入10个无序的数字
排序好的10个整数
4 85 3 234 45 345 345 122 30 12
样例输出:
3
4
12
30
45
85
122
234
345
345
代码实现:
#include <stdio.h>
void main()
{
	int arr[10];
	int i, j;
	for(i = 0; i < 10; i++)
	{
		scanf("%d", &arr[i]);
	}
//j<10即可因为前面的数已经排好,而冒泡排序是后面的数排好,二者要区分 
	for(i = 0; i < 10-1; i++)
	{
		for(j = i+1; j < 10; j++) 
		{
			if(arr[i] > arr[j])
			{
				int temp = arr[j];
				arr[j] = arr[i];
				arr[i] = temp;
			}
		}
	}
	for(i = 0; i < 10; i++)
	{
		printf("%d\n", arr[i]);
	}
}
//以升序为例先将第一个数与后面所有数比较,排出最小的放在最前面。再从第二个数开始与第二个数之后的所有数进行比较,将第二小的数放在第二位......0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复