簡單選擇排序算法:
一趟選擇排序:
通過n-i次關鍵字間的比較,從n-i+1個記錄中選擇出最小的記錄,並和第i(1<= i <= n)個記錄交換之。
代碼:
#include<stdio.h>
#define MAXSIZE 20 //數組大小
typedef int KeyType; //關鍵字類型
typedef int InfoType; //元素信息類型
//數組中元素的信息
typedef struct{
KeyType key; //元素排序的關鍵字
InfoType otherinfo; //元素信息
}RedType;
//數組的類型
typedef struct{
RedType r[MAXSIZE+1];
int length;
}SqList;
//初始化待排序列
void Init(SqList *L,int a[],int length)
{
int i;
RedType rt;
for(i = 0;i < length;i++){
rt.key = a[i];
rt.otherinfo = i;
L->r[i] = rt;
}
L->length = length;
}
//交換數組中兩元素的值
void swap(RedType *p,RedType *q){
RedType temp = *p;
*p = *q;
*q = temp;
}
//查詢數組中key最小元素的下標
int SelectMinKey(SqList *L,int i){
int j,min = i;
for(j = i;j < L->length;j++){
if(L->r[j].key < L->r[min].key)
min = j;
}
return min;
}
//選擇排序主程序
void SelectSort(SqList *L){
int i,j,k,l;
for(i = 0;i<L->length;++i){
j = SelectMinKey(L,i);
if(i != j){
printf("\n\n第%d趟 從小標爲%d開始找最小值:min = %d 交換 %d <=> %d \n",i,i,L->r[j].key,L->r[i].key,L->r[j].key);
swap(&(L->r[i]),&(L->r[j]));
printf("交換後:");
for(k = 0;k < 9;k++){
printf("%-2d ",L->r[k].key);
}
printf("\n下標號:");
for(l = 0;l < 9;l++){
printf("%-2d ",L->r[l].otherinfo);
}
}
}
}
int main(){
SqList L;
int i;
int a[9] = {0,49,38,65,97,76,13,27,49};
Init(&L,a,9);
printf("排序前:");
for(i = 0;i < 9;i++){
printf("%-2d ",L.r[i].key);
}
printf("\n下標號:");
for(i = 0;i < 9;i++){
printf("%-2d ",L.r[i].otherinfo);
}
SelectSort(&L);
printf("\n\n排序後:");
for(i = 0;i < 9;i++){
printf("%-2d ",L.r[i].key);
}
printf("\n下標號:");
for(i = 0;i < 9;i++){
printf("%-2d ",L.r[i].otherinfo);
}
printf("\n\n");
return 0;
}
運行效果圖:
第一趟中從0下標開始往後找最小元素,結果最小元素就是0下標出的元素,所以不做交換。