选择法排序

本题要求将给定的n个整数从大到小排序后输出。

输入格式:

输入第一行给出一个不超过10的正整数n。第二行给出n个整数,其间以空格分隔。

输出格式:

在一行中输出从大到小有序的数列,相邻数字间有一个空格,行末不得有多余空格。

输入样例:

复制代码
4
5 1 7 6

输出样例:

复制代码
7 6 5 1

代码:

cpp 复制代码
#include<stdio.h>

int main()
{
	int n;
	scanf("%d", &n);
	int a[12];
	for (int i = 0; i <n; i++)
	{
		scanf("%d", &a[i]);
	}
	int b = 0;
	int t = 0;
	for (int i = 0; i < n-1; i++)//总共需排序n-1次
	{
		b = i;
		for (int j = i+1; j < n; j++)//j=i+1 从剩下的数中找到最大值
		{
			if (a[j] > a[b])
			{
				//直接交换下标,相当于利用循环交换元素,不用直接交换元素如b = a[j];
				b = j;
			}
		}
		t = a[i];
		a[i] = a[b];
		a[b] = t;//找到最大值后交换两值
	}
	for (int i = 0; i < n; i++)
	{
		if (i < n - 1)//最后一个不带空格
			printf("%d ", a[i]);
		else
			printf("%d", a[i]);
	}
	return 0;
}
相关推荐
white-persist4 小时前
差异功能定位解析:C语言与C++(区别在哪里?)
java·c语言·开发语言·网络·c++·安全·信息可视化
dangdang___go5 小时前
自定义类型:结构体
c语言·结构体·结构体的声明·结构体的自引用
码界奇点6 小时前
Linux进程间通信三System V 共享内存完全指南原理系统调用与 C 封装实现
linux·c语言·网络·c++·ux·risc-v
..过云雨7 小时前
13.【Linux系统编程】从ELF格式深入理解动静态库
linux·c语言·c++·后端
智者知已应修善业8 小时前
【给定英文字符串统计最多小写最前输出】2023-2-27
c语言·开发语言·c++·经验分享·笔记·算法
无限进步_9 小时前
C语言atoi函数实现详解:从基础到优化
c语言·开发语言·c++·git·后端·github·visual studio
树在风中摇曳10 小时前
【C语言预处理器全解析】宏、条件编译、字符串化、拼接
c语言·算法
fashion 道格10 小时前
用 C 语言破解汉诺塔难题:递归思想的实战演练
c语言·算法
yuuki23323311 小时前
【数据结构】常见时间复杂度以及空间复杂度
c语言·数据结构·后端·算法
byte轻骑兵12 小时前
【安全函数】C语言安全字符串函数详解:告别缓冲区溢出的噩梦
c语言·安全·面试