算法的时间复杂度为 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;
}
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;
}