C语言--利用选择法对数组中的10个整数按由小到大排序


一.选择法排序介绍🍗

所谓选择法就是先将10个数中最小的数字与arr[0]交换,再将arr[1]-arr[9]中最小的数字与arr[1]进行交换....每一次比较,找出一个未经排序的数中最小的一个。总共比较9轮。

下面以5个数字为例说明选择法的步骤。


二.完整代码

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>  //引用头文件
//选择法排序
//利用选择法对数组中的10个整数按由小到大排序
void Sort(int arr[], int sz)
{
	int k; //k是最小值的下标
	int tmp;
	//sz个数字,要交换sz-1次完成排序
	for (int i = 0;i < sz - 1;i++)
	{
		k = i;//假设最小值的下标是i
		//找出最小的数字
		for (int j = i+1;j < sz;j++)
		{
			if (arr[j] < arr[k])
			{
				k = j; //此时j为最小值的下标
				
				//交换数字
				tmp = arr[k];
				arr[k] = arr[i];
				arr[i] = tmp;
			}
		}
	}
}
int main()
{
	int arr[10] = { 0 };
	printf("请输入10个数字 :");
	int sz = sizeof(arr) / sizeof(arr[0]);
	for (int i = 0;i<sz;i++)
	{
		scanf("%d", &arr[i]);
	}
	printf("原来的数组是:\n");
	
	for (int i = 0;i < sz;i++)
	{
		printf("%d ", arr[i]);
	}
	Sort(arr, sz);
	printf("\n");
	printf("排序后的数组是\n");
	for (int i = 0;i < sz;i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

三.运行结果


创作不易, 如果这份博客👍对你有帮助,可以给博主一个免费的点赞以示鼓励。

相关推荐
web安全工具库1 小时前
Makefile 模式规则精讲:从 %.o: %.c 到静态模式规则的终极自动化
linux·运维·c语言·开发语言·数据库·自动化
earthzhang20214 小时前
【1028】字符菱形
c语言·开发语言·数据结构·c++·算法·青少年编程
承渊政道8 小时前
动态内存管理
c语言·c++·经验分享·c#·visual studio
Narcissiffo9 小时前
【C语言】str系列函数
c语言·开发语言
hqyjzsb10 小时前
2025年市场岗位能力重构与跨领域转型路径分析
c语言·人工智能·信息可视化·重构·媒体·改行学it·caie
小莞尔10 小时前
【51单片机】【protues仿真】基于51单片机智能窗帘系统
c语言·stm32·单片机·嵌入式硬件·物联网·51单片机
懒羊羊不懒@10 小时前
Java基础语法—最小单位、及注释
java·c语言·开发语言·数据结构·学习·算法
SundayBear11 小时前
嵌入式进阶:C语言内联汇编
c语言·开发语言·汇编
小龙报14 小时前
《算法通关指南---C++编程篇(2)》
c语言·开发语言·数据结构·c++·程序人生·算法·学习方法
C++ 老炮儿的技术栈16 小时前
include″″与includ<>的区别
c语言·开发语言·c++·算法·visual studio