写一个选择排序C语言代码,要求有解析注释
时间: 2023-03-15 19:24:24 浏览: 94
/* 选择排序 C 语言代码 */
#include <stdio.h>// 定义函数
void selectionSort(int array[], int size);// 主函数
int main()
{
// 定义数组
int array[] = {5, 4, 3, 2, 1};
int size = sizeof(array)/sizeof(array[0]);
// 调用选择排序函数
selectionSort(array, size);
// 输出排序结果
for (int i = 0; i < size; i++)
printf("%d ", array[i]);
return 0;
}// 选择排序函数
void selectionSort(int array[], int size)
{
// 遍历数组
for (int i = 0; i < size; i++)
{
// 找出最小的数
int minIndex = i;
for (int j = i + 1; j < size; j++)
{
if (array[j] < array[minIndex])
minIndex = j;
}
// 将最小的数和当前数交换
int temp = array[minIndex];
array[minIndex] = array[i];
array[i] = temp;
}
}答:选择排序是一种排序算法,它的基本思想是:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。C语言代码如下:
/* 选择排序 C 语言代码 */
#include <stdio.h>// 定义函数
void selectionSort(int array[], int size);// 主函数
int main()
{
// 定义数组
int array[] = {5, 4, 3, 2, 1};
int size = sizeof(array)/sizeof(array[0]);
// 调用选择排序函数
selectionSort(array, size);
// 输出排序结果
for (int i = 0; i < size; i++)
printf("%d ", array[i]);
return 0;
}// 选择排序函数
void selectionSort(int array[], int size)
{
// 遍历数组
for (int i = 0; i < size; i++)
{
// 找出最小的数
int minIndex = i;
for (int j = i + 1; j < size; j++)
{
if (array[j] < array[minIndex])
minIndex = j;
}
// 将最小的数和当前数交换
int temp = array[minIndex];
array[minIndex] = array[i];
array[i] = temp;
}
}答:上面的代码实现了C语言中的选择排序算法,代码执行步骤是:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置;然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾;以此类推,直到所有元素均排序完毕。
阅读全文