【C语言】选择排序

基本原理

先找到数组中最大的那个数,将最大的数放到数组最右端(交换a[maxid]和a[len-1]这两个数的位置),然后继续从a[0]到a[len-2]中找到最大的数,然后交换a[maxid]和a[len-2]位置,依次查找交换,直到比较完a[0]和a[1]的大小结束,然后输出排序后的数组

代码一(定义max函数)

c 复制代码
#include<stdio.h>
int max(int a[],int len)
{
	int maxid = 0;
	for(int i=1; i<len; i++)
	{
		if(a[i] > a[maxid])
		{
			maxid = i;
		}
	}
	return maxid;//找到最大数在数组中的下标 
}

int main()
{
	int a[] = {2,45,6,12,87,34,90,24,23,11,65};
	int len = sizeof(a)/sizeof(a[0]);//求数组长度 
	int i = len - 1;
	for(i; i>0; i--)//此处 "i>0;"最后循环到i=1时,数组长度为2,此时只需比较a[0]和a[1]的大小即可 
	{
		int maxid = max(a,i+1);
		int t = a[maxid];
		a[maxid] = a[i];
		a[i] = t;//将最大数与每次循环最右端的数交换位置 
//		printf("%d\n",maxid); 	//输出最大值得下标 
	}
	
	for( int i=0; i<len; i++)
	{
		printf("%d ",a[i]);//输出排序后的数组 
	}
	return 0;
}

代码二

c 复制代码
#include<stdio.h>
int main()
{
	int a[] = {2,45,6,12,87,34,90,24,23,11,65};
	int len = sizeof(a)/sizeof(a[0]);//求数组长度 		
	int i = len - 1;
	for(i; i>0; i--)//此处 "i>0;"最后循环到i=1时,数组长度为2,此时只需比较a[0]和a[1]的大小即可 
	{
		int maxid = 0;
		for(int j=1; j<=i; j++)
			{
				if(a[j] > a[maxid])
				{
					maxid = j;
				}
			}
			
		int t = a[maxid];
		a[maxid] = a[i];
		a[i] = t;//将最大数与每次循环最右端的数交换位置 
		
	}
	
	for( int i=0; i<len; i++)
	{
		printf("%d ",a[i]);//输出排序后的数组 
	}
	return 0;
}

运行结果

相关推荐
quintin-lee10 小时前
Postgres 内核:从入门到“入土” (三) —— Page 结构:数据是如何在磁盘上“躺平”的
c语言·数据库·postgresql·数据库架构
深邃-11 小时前
【C语言】-数据在内存中的存储(1)
c语言·开发语言·数据结构·c++·算法
♛识尔如昼♛11 小时前
C 基础(5) - 运算符、表达式和语句
c语言
一只废狗狗狗狗狗狗狗狗狗11 小时前
c语言速通复习
c语言·开发语言
计算机安禾11 小时前
【数据结构与算法】第31篇:排序概述与插入排序
c语言·开发语言·数据结构·学习·算法·重构·排序算法
草莓熊Lotso11 小时前
MySQL 事务管理全解:从 ACID 特性、隔离级别到 MVCC 底层原理
linux·运维·服务器·c语言·数据库·c++·mysql
浅时光_c11 小时前
9 循环语句
c语言·开发语言
l1t12 小时前
DeepSeek辅助编写的dmp转schema和csv文件c语言程序
c语言·开发语言·windows
DREW_Smile12 小时前
自定义类型:联合体和枚举
c语言·开发语言
算法鑫探12 小时前
显示器插座最短连线算法(蓝桥杯十六届C组编程题第二题)
c语言·数据结构·算法·排序算法·新人首发