博客
关于我
【排序】选择排序及其优化
阅读量:497 次
发布时间:2019-03-07

本文共 1824 字,大约阅读时间需要 6 分钟。

一、选择排序

void SelectSort(int* array, int size){    //size-1:每次都会排好一个数据,所以每次都需要进行-1    for (int i = 0; i < size - 1; i++)    {        //用maxPos标记最大的数据        int maxPos = 0;        //size-i:后面数据已经排好序了,直接不用管        for (int j = 0; j < size - i; j++)        {            //找最大的数据            if (array[j] > array[maxPos])                maxPos = j;        }            //如果最大的数据就是最后一个,就没有比较进行比较            if (maxPos != size - i - 1)                Swap(&array[maxPos], &array[size - i - 1]);    }}

 

二、选择排序优化

优化点:上述代码是一次找一个,这次我们同时找最大的和最小的,和对应的位置交换

 

void SelectSortOP(int* array, int size){    //定义这个就是减少范围来的,将已经排序好的直接去掉    int begin = 0;    int end = size - 1;    //标记最大或者最小的元素,以便于之后交换    int MaxPos = begin;    int MinPos = begin;    while (begin < end)    {        //index用于遍历数组        int index = begin + 1;        //标记最大最小的元素        while (index <= end)        {            if (array[MaxPos] < array[index])                MaxPos = index;            if (array[MinPos] > array[index])                MinPos = index;            ++index;        }        //交换        if (MinPos != left)            Swap(&array[MinPos], &array[left]);        if (MaxPos != end)            Swap(&array[MaxPos], &array[end]);        begin++;        end--;    }}

 

 

三、选择排序优化2

优化点:此时的代码还存在一点瑕疵,如果最小值在最后侧的话,那么交换的时候,MinPos会更新

void SelectSort_2(std::vector
&arr){ int len = arr.size(); int left = 0; int right = len - 1; while(left < right) { int min_pos = left; int max_pos = left; for(int i = left; i <= right; ++i){ if(arr[min_pos] > arr[i]){ min_pos = i; } if(arr[max_pos] < arr[i]){ max_pos = i; } } if(min_pos != left) swap(arr[min_pos], arr[left]); if(max_pos == left){ max_pos = min_pos; } if(max_pos != right) swap(arr[max_pos], arr[right]); ++left, --right; }}

 

转载地址:http://xfacz.baihongyu.com/

你可能感兴趣的文章
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>