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

运行结果

相关推荐
单片机系统设计几秒前
基于STM32单片机的智能恒温水壶设计
c语言·stm32·单片机·嵌入式硬件·毕业设计·智能温水壶
进击的小头13 分钟前
18_C语言算法面试与进阶:高频算法题实战与学习路线规划
c语言·算法·面试
烛衔溟17 分钟前
C语言并发编程:Windows线程
c语言·c++·windows·性能优化·多线程·并发编程·线程同步
HUST30 分钟前
C语言 第十讲:操作符详解
c语言·开发语言
凑凑的小手办39 分钟前
C语言基础(一)
c语言·开发语言
黎雁·泠崖1 小时前
二叉树入门全攻略:从树的概念到遍历实现
c语言·数据结构
你怎么知道我是队长1 小时前
C语言---共用体
c语言·开发语言·算法
枫叶丹42 小时前
【Qt开发】Qt系统(四)-> Qt文件
c语言·开发语言·c++·qt
TDengine (老段)3 小时前
TDengine C/C++ 连接器进阶指南
大数据·c语言·c++·人工智能·物联网·时序数据库·tdengine
黎雁·泠崖4 小时前
栈与队列实战通关:3道经典OJ题深度解析
c语言·数据结构·leetcode