当前位置: 首页 > article >正文

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


 一.选择法排序介绍🍗

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

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


二.完整代码

#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;
}

 三.运行结果


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


http://www.kler.cn/a/145234.html

相关文章:

  • AI 的安全性与合规性:实践中的最佳安全策略
  • 每日一题——序列化二叉树
  • 【NLP251】意图识别 与 Seq2Seq
  • C++模板初识
  • 巴塞尔问题详解:计算所有正整数平方的倒数之和
  • 生成模型:扩散模型(DDPM, DDIM, 条件生成)
  • 13年老鸟总结,性能测试方法汇总+性能响应很慢排查方法(详全)
  • Linux内核--内存管理(十三)vmalloc的实现
  • 流程图是什么,用什么软件做?
  • WIFI模块(esp-01s)获取网络时间与天气信息
  • VCenter连接主机提示:未验证主机SSL证书的真实性
  • ArcGIS中基于人口数据计算人口密度的方法
  • MYSQL基础知识之【修改数据,删除数据】
  • 可燃气体监测仪助力燃气管网安全监测,效果一览
  • 【深度优先搜索】
  • Centos上安装Docker和DockerCompose
  • 利用ngrok实现内网穿透(全网最详细教程)
  • 什么是 TLS/SSL 握手
  • 区块链技术与应用 【全国职业院校技能大赛国赛题目解析】第四套区块链应用后端开发
  • flex布局实战之自动填充剩余
  • 4D Gaussian Splatting:用于实时的动态场景渲染
  • 网络篇---第一篇
  • 【华为OD】B\C卷真题:100%通过:找城市 C/C++实现
  • 云下的我们
  • ElasticSearch之配置
  • CSS新手入门笔记整理:CSS基本选择器