选择法排序

本题要求将给定的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;
}
相关推荐
handler0113 分钟前
Git 核心指令速查
linux·c语言·c++·笔记·git·学习
学会去珍惜19 分钟前
学会C语言可以做什么
c语言·网络编程·游戏开发·嵌入式系统·系统编程
『昊纸』℃1 小时前
Mac上编译C语言的简易方法
c语言·mac·教程·xcode·编译
代码中介商1 小时前
C语言核心知识完全回顾:从数据类型到动态内存管理
c语言·开发语言
xiaobobo33301 小时前
c语言源文件中#include包含头文件的起始路径是哪里?
c语言·头文件包含·起始路径·起始点
jimy12 小时前
C语言中的 “size_t ”类型
c语言·开发语言
wuminyu2 小时前
专家视角看Lambda表达式的原理解析
java·linux·c语言·jvm·c++
modelmd2 小时前
研究C语言的hello world输出
c语言·开发语言·chrome
12.=0.3 小时前
【stm32_7】定时器的原理与应用、基本定时器、通用定时器、PWM、模拟脉冲信号的宽度、利用PWM控制外设、逻辑分析仪的使用
c语言·stm32·单片机·嵌入式硬件
jimy13 小时前
C语言历史版本和gnu扩展版本
c语言·算法·gnu