排序——选择排序

基本思想

每一趟在待排序元素中选取关键字最小的元素加入有序子序列。

算法代码

#include 
using namespace std;

//选择排序 
void SelectSort(int nums[],int n){
	int i,j,min;
	for(i=0;inums[j]){	
				min=j;				//更新最小元素下标 
			}
		}
		if(min!=i){					 
			swap(nums[i],nums[min]);//将当前元素和找到的最小元素进行交换 
		}
	}
}

//交换函数 
void swap(int &a,int &b){
	int temp;
	temp=a,a=b,b=temp;
} 

//打印数组 
void printNum(int numbers[],int n){
	for(int i=0;i

算法性能分析

  • 空间复杂度: O ( 1 ) O(1) O(1)

  • 时间复杂度: O ( n 2 ) O(n^2) O(n2)

  • 算法稳定性1:不稳定


  1. 算法的稳定性:若待排序表中有两个元素 R i R_i Ri R j R_j Rj,其对应的关键字相同即 k e y i = k e y j key_i = key_j keyi=keyj,且在排序前 R i R_i Ri R j R_j Rj 的前面,若使用某一排序算法排序后, R i R_i Ri 仍在 R j R_j Rj 的前面,则称这个排序算法是稳定,否则称排序算法是不稳定的。 ↩︎

你可能感兴趣的:(数据结构,#,排序算法,算法,排序算法,数据结构)