选择排序的C语言代码
时间: 2023-11-12 12:56:47 浏览: 170
选择排序的C语言代码如下:
```c
void selectionSort(int arr[], int n) {
int i, j, min_idx;
for (i = 0; i < n-1; i++) {
min_idx = i;
for (j = i+1; j < n; j++)
if (arr[j] < arr[min_idx])
min_idx = j;
swap(&arr[min_idx], &arr[i]);
}
}
```
其中,`swap` 函数用于交换两个元素的值。
相关问题
选择排序C语言代码实例
以下是选择排序的C语言代码实例:
```
#include <stdio.h>
void selectionSort(int arr[], int n) {
int i, j, min_idx;
for (i = 0; i < n-1; i++) {
min_idx = i;
for (j = i+1; j < n; j++)
if (arr[j] < arr[min_idx])
min_idx = j;
int temp = arr[min_idx];
arr[min_idx] = arr[i];
arr[i] = temp;
}
}
void printArray(int arr[], int size) {
int i;
for (i=0; i < size; i++)
printf("%d ", arr[i]);
printf("\n");
}
int main() {
int arr[] = {64, 25, 12, 22, 11};
int n = sizeof(arr)/sizeof(arr[0]);
selectionSort(arr, n);
printf("Sorted array: \n");
printArray(arr, n);
return 0;
}
```
这段代码实现了选择排序算法,可以对一个整数数组进行排序。
写一个选择排序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语言代码如下:
/* 选择排序 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语言中的选择排序算法,代码执行步骤是:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置;然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾;以此类推,直到所有元素均排序完毕。
相关推荐
![h](https://img-home.csdnimg.cn/images/20210720083646.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)