选择排序算法

选择排序大体思路是找到数组中最小的那个元素,其次,将它和数组的第一个元素交换位置(如果第一个元素就是最小元素那么它就和自己交换)。其次,在剩下的元素中找到最小的元素,将它与数组的第二个元素交换位置。如此往复,直到将整个数组排序。选择排序的算法效率不是很高,时间复杂度O(n2) ,空间复杂度:O(1) 。

一、声明选择排序函数

cpp 复制代码
#ifndef  _ALG_H
#define  _ALG_H
#include <stdlib.h>
#include <stdio.h>

typedef  unsigned int  DataField;

void   show_data(DataField* data,int len);

/**
 *选择排序
*/
void  select_sort(DataField* data, int len);

#endif

二、定义选择排序函数

cpp 复制代码
#include "alg.h"

void show_data(DataField *data, int len)
{
    printf("-----------------\n");
    int i = 0;
    for (i; i < len; i++)
    {
        printf("%d\t",*(data+i));
    }
    printf("\n");
}


void select_sort(DataField* data, int len)
{
    int i = 0;
    for (i; i < len - 1; i++)
    {
        int min = i;
        int j;
        /// 每一轮循环找出剩余元素的最小值
        for (j = i + 1; j < len; j++)
        {
            min = *(data + min) > *(data + j) ? j : min;
        }
        /// 将当前找到的最小值放到第i个元素的位置
        DataField temp = *(data + min);
        *(data + min) = *(data + i);
        *(data + i) = temp;
    }
    show_data(data,len);
}

三、测试排序结果

cpp 复制代码
void  (*funPtr)(DataField*,int);

int main()
{
    DataField arr[] ={ 19,29,49,69,99,39,9,79,89 };
    DataField* data = &arr[0];
    int len =  sizeof(arr)/sizeof(DataField);
    
    funPtr =  &select_sort;
    (*funPtr)(data,len);

    while (1) {}
    ///getchar()
    exit(0);
}
相关推荐
Dr.92717 分钟前
1-10 目录树
java·数据结构·算法
双叶83620 分钟前
(C语言)超市管理系统 (正式版)(指针)(数据结构)(清屏操作)(文件读写)(网页版预告)(html)(js)(json)
c语言·javascript·数据结构·html·json
子豪-中国机器人29 分钟前
C++ 蓝桥 STEMA 省选拔赛模拟测试题(第一套)
开发语言·c++·算法
callJJ31 分钟前
Bellman - Ford 算法与 SPFA 算法求解最短路径问题 ——从零开始的图论讲解(4)
数据结构·算法·蓝桥杯·图论·单源最短路径·bellman- ford算法
圈圈编码34 分钟前
LeetCode Hot100刷题——轮转数组
java·算法·leetcode·职场和发展
金融小师妹5 小时前
应用BERT-GCN跨模态情绪分析:贸易缓和与金价波动的AI归因
大数据·人工智能·算法
广州智造5 小时前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
Trent19857 小时前
影楼精修-肤色统一算法解析
图像处理·人工智能·算法·计算机视觉
feifeigo1237 小时前
高光谱遥感图像处理之数据分类的fcm算法
图像处理·算法·分类
北上ing8 小时前
算法练习:19.JZ29 顺时针打印矩阵
算法·leetcode·矩阵