对于给定的含有n个元素的数组a,对其按元素值递增排序。(利用简单选择排序法)c语言代码
时间: 2024-10-10 09:13:03 浏览: 66
在C语言中,我们可以使用简单选择排序算法对数组进行递增排序。简单选择排序的基本思想是在未排序部分找到最小元素并将其放到已排序部分的末尾。以下是针对n个整数数组的简单选择排序代码:
```c
#include <stdio.h>
void selectionSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) { // 遍历所有元素,直到倒数第二个
int minIndex = i; // 初始化最小元素索引为当前下标
for (int j = i + 1; j < n; j++) { // 比较当前元素和后面的元素
if (arr[j] < arr[minIndex]) {
minIndex = j; // 如果找到更小的元素,更新最小索引
}
}
// 将找到的最小元素与未排序部分的第一个元素交换
int temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;
}
}
// 测试函数
int main() {
int a[] = {9, 5, 7, 3, 1, 8, 6}; // 示例数组
int n = sizeof(a) / sizeof(a[0]);
printf("原始数组: ");
for (int i = 0; i < n; i++) {
printf("%d ", a[i]);
}
selectionSort(a, n);
printf("\n升序排列后的数组: ");
for (int i = 0; i < n; i++) {
printf("%d ", a[i]);
}
return 0;
}
```
这个程序首先定义了一个`selectionSort`函数,然后在`main`函数中创建一个示例数组,并调用`selectionSort`对其进行排序。运行这个程序,你会看到数组a按递增顺序排列的结果。
阅读全文