簡單選擇排序

簡單選擇排序算法:

一趟選擇排序:

通過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下標出的元素,所以不做交換。

運行效果圖

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章