算法的时间复杂度为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;
}
本文介绍了一种简单直观的排序算法——选择排序。该算法通过不断地选择数组中的最大元素,并将其放到已排序序列的末尾来实现排序过程。算法的时间复杂度为O(n^2),适用于小型数据集的排序。
1536

被折叠的 条评论
为什么被折叠?



