4.选择排序

一、思想

代码:

二、时间复杂度:

看似其时间复杂度就是一个for循环的大O(N),但实际上每次进行扫描最小元的时候都要做一次for循环,所以其时间复杂度是俩嵌套一起的for循环,故此其时间复杂度是:

但是,每次扫描最小元,每次取的都是最小元?怎么快速找到最小元呢?我们可以利用树中的最小堆来优化这个选择排序!这也就是堆排序的由来。

三、代码实现:

cpp 复制代码
#include<stdio.h>
typedef int ElementType;
int ScanForMin(ElementType A[],int i,int N){
	int j,MinPosition;
	MinPosition = i;
	for(j=i;j<=N;j++){
		if(A[j]<A[MinPosition]){
			MinPosition = j;
		}
	}
	return MinPosition;
} 
void Swap(ElementType* x,ElementType* y){
	ElementType temp = *x;
	*x = *y;
	*y = temp;
} 
void display(ElementType x[]){
	int i;
	for(i=0;i<10;i++){
		printf("%d\t",x[i]);
	}
}
void Selection_Sort(ElementType A[],int N)
{
	int i,MinPosition;
	for(i=0;i<N;i++){
		MinPosition = ScanForMin(A,i,N-1);//从A[i]到A[N-1]寻找最小元位置赋给MinPosition 
		Swap(&A[i],&A[MinPosition]);//将未排序部分的最小元放到有序部分的最后位置 
		display(A);
		printf("\n");
	}
}
int main(){
	ElementType A[10] = {9,8,7,6,5,4,3,2,1,0};
	display(A);
	printf("\n");
	Selection_Sort(A,10);
	return 0;
}
相关推荐
lin_FS40 分钟前
反转局部链表
数据结构·算法
艾莉丝努力练剑1 小时前
【数据结构与算法】数据结构初阶:详解排序(三)——归并排序:递归版本和非递归版本
c语言·开发语言·数据结构·学习·算法·链表·排序算法
屁股割了还要学1 小时前
【C语言进阶】题目练习
c语言·开发语言·数据结构·学习·算法·青少年编程
oneway_up2 小时前
并查集介绍及典型应用和编程题
数据结构
刚入坑的新人编程4 小时前
暑期算法训练.10
数据结构·c++·算法·排序算法
今天你睡了嘛5 小时前
数据结构——图(二、图的存储和基本操作)
数据结构·算法·图论
姜行运6 小时前
数据结构【红黑树】
数据结构·c++·c#
RXXW_Dor8 小时前
数据结构之线性表
数据结构
云边有个稻草人9 小时前
【C++】第十九节—一文万字详解 | AVL树实现
数据结构·c++·avl树·avl树的插入·avl树的旋转·avl树实现·avl树的结构
晨非辰10 小时前
#C语言——学习攻略:深挖指针路线(三)--数组与指针的结合、冒泡排序
c语言·开发语言·数据结构·学习·算法·排序算法·visual studio