從字面上理解,就是通過不斷地選擇數組元素,從而達到排序的目的。我插入排序類似,假設第i(i<n)個數組元素data[0]是最大的(從大到小排序),然后依次掃描i + 1 到 n - 1的元素,找到比第i個元素大的元素。最后將它們交換。
算法的時間復雜度為
O(n^2)。
算法的實現如下
#include <stdio.h>
void output_array(int data[], int n)
{
int i;
for(i = 0; i < n; i++)
printf("%d ", data[i]);
printf("\n");
}
void swap(int *a, int *b)
{
int x;
x = *a;
*a = *b;
*b = x;
}
//算法實現
void selection(int data[], int b, int e)
{
int i, j, high_index;
for(i = b; i < e; i++)
{
high_index = i;
for(j = e; j > i; j--)
if(data[j] > data[high_index])
high_index = j;
swap(&data[i], &data[high_index]);
}
}
int main()
{
int data[] = {5, 3, 1, 665, 77, 66, 44, 11, 10, 9, 8, 6};
output_array(data, 12);
selection(data, 0, 11);
output_array(data, 12);
return 0;
}
新浪微博:http://t.sina.com.cn/androidguy 昵稱:李寧_Lining