c语言的选择排序法数组
时间: 2023-10-17 09:06:52 浏览: 105
选择排序是一种简单且直观的排序算法,其原理是每次从未排序的部分中选择最小(或最大)的元素,并将其放置在已排序部分的末尾。具体实现可以参考以下代码:
//交换两个数据
void Swap(int* a, int* b) {
int temp = *a;
*a = *b;
*b = temp;
}
//选择排序
void SelectSort(int* arr, int size) {
int i = 0;
for (i = 0; i < size-1; i++) {
int min = i;
int j = 0;
for (j = i+1; j < size; j++) {
if (arr[j] < arr[min]) {
min = j;
}
}
Swap(&arr[i], &arr[min]);
}
}
这段代码使用了两个函数,Swap用于交换两个元素的值,SelectSort用于实现选择排序。选择排序的时间复杂度为O(n^2),空间复杂度为O(1)。
相关问题
c语言使用选择法数组排序
C语言中的选择排序算法是一种简单直观的排序方法,它适用于小型数组或数据量较少的情况。选择排序的基本思想是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。
以下是C语言中选择排序的一种基本实现:
```c
void selectionSort(int arr[], int n) {
int i, j, minIndex, temp;
for (i = 0; i < n - 1; i++) { // 遍历数组
minIndex = i; // 初始化最小值索引为当前索引
// 找到剩余未排序部分中的最小值
for (j = i + 1; j < n; j++) {
if (arr[j] < arr[minIndex]) {
minIndex = j;
}
}
// 将找到的最小值与当前位置交换
temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;
}
}
```
在这个函数中,`arr[]` 是输入的整数数组,`n` 是数组长度。外层循环遍历数组,内层循环则在剩下的未排序部分中寻找最小值并更新其位置。每完成一轮外部循环,整个数组都会向前推进一步,直到所有元素都被排序。
用c语言选择法对数组中的数据排序(从小到大)。
在C语言中,选择法是一种简单的排序算法,也被称为直接选择排序。它的基本思想是每次从未排序的部分中选出最小(或最大)的元素放到已排序部分的末尾。以下是选择排序的具体步骤:
1. **初始化**:假设有一个未排序的数组`arr`,以及两个指针`i`和`j`,`i`用于遍历已排序部分,初始值为0;`j`用于查找未排序部分的最小元素,初始值为`i+1`。
2. **找到最小元素**:在未排序的子数组(从索引`i`到数组长度)中,找到最小的元素`arr[j]`。
3. **交换**:如果这个最小元素在已排序部分之后(即`arr[j] < arr[i]`),则交换这两个位置的元素。
4. **移动边界**:将`i`向前移动一位,并将`j`重置回`i+1`,继续查找并交换下一个最小元素。
5. **重复**:直到`i`达到未排序部分的末尾(即`i = n - 1`,其中`n`是数组长度),排序过程结束。
下面是一个简单的C语言实现选择排序的示例:
```c
#include <stdio.h>
void selection_sort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
int min_index = i;
for (int j = i + 1; j < n; j++) {
if (arr[j] < arr[min_index]) {
min_index = j;
}
}
// 交换找到的最小元素和当前未排序部分的第一个元素
int temp = arr[i];
arr[i] = arr[min_index];
arr[min_index] = temp;
}
}
// 测试函数
int main() {
int arr[] = {64, 25, 12, 22, 11};
int n = sizeof(arr) / sizeof(arr[0]);
selection_sort(arr, n);
printf("Sorted array: ");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
当你运行这段代码,它会打印出排序后的数组,从小到大排列。
阅读全文