选择法排序(c语言)

选择法排序:是指先将a[0]至a[n]中的最小元素与a[0]交换;再将a[1]~a[n]中的最小元素与a[1]交换……,每进行一轮比较,找出当前未排序数中的最小元素。比较n-1轮后,排序结束。

#include <stdio.h> 
void main()
{   
int i, j, p, t, a[10];
    printf("\n input 10 numbers:\n");
    for (i=0;i<10;i++)
        scanf("%d", &a[i]);
    for (i=0;i<10;i++)  //第i轮排序
	{   p=i; 
        for (j=i+1;j<10;j++)  //找最小元素
	          if (a[j]<a[p])  p=j; 
        if (i!=p)  { t=a[i];  a[i]=a[p];  a[p]=t; }  //交换
        printf("%8d",a[i]);
    }
}
### C语言实现选择排序算法 选择排序是一种简单的排序方法,其基本思想是从待排序序列中找到最小(或最大)的元素并将其放到已排序序列的末尾。以下是基于C语言的选择排序算法详解以及其实现代码。 #### 选择排序算法原理 选择排序的核心在于每次从未排序部分选取一个最小值,并将其放置到当前未排序部分的起始位置。这一过程重复执行直到整个数组完成排序[^3]。 #### 示例代码 以下是一个完整的C语言程序,用于实现选择排序: ```c #include <stdio.h> // 定义交换函数 void Swap(int *a, int *b) { int temp = *a; *a = *b; *b = temp; } // 实现选择排序 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; // 更新最小值索引 } } if (minIndex != i) { // 如果发现更小值,则进行交换 Swap(&arr[i], &arr[minIndex]); } } } // 打印数组 void PrintArray(const int arr[], int size) { for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } printf("\n"); } int main() { int data[] = {52, 36, 2, 39, 56, 45, 78, 92, 15, 52}; // 输入数据 int n = sizeof(data) / sizeof(data[0]); printf("原始数组: "); PrintArray(data, n); SelectionSort(data, n); // 调用选择排序函数 printf("排序后的数组: "); PrintArray(data, n); return 0; } ``` 上述代码实现了选择排序的功能,其中`Swap()`函数负责两个数之间的交换操作;`SelectionSort()`函数则完成了核心逻辑——通过双重循环逐步定位每一轮中的最小值并调整顺序。 #### 运行结果分析 对于给定的数据集 `{52, 36, 2, 39, 56, 45, 78, 92, 15, 52}`,运行以上代码后可以得到从小到大的排列结果 `2 15 36 39 45 52 52 56 78 92`。 ---
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陈勇劲

你的鼓励实我最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值