博客
关于我
【排序】选择排序及其优化
阅读量: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/

你可能感兴趣的文章
Nginx安装与常见命令
查看>>
Nginx安装及配置详解
查看>>
Nginx实战经验分享:从小白到专家的成长历程!
查看>>
Nginx实现反向代理负载均衡
查看>>
nginx实现负载均衡
查看>>
nginx开机启动脚本
查看>>
nginx异常:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf
查看>>
nginx总结及使用Docker创建nginx教程
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx.conf:128
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in usrlocalnginxconfnginx.conf128
查看>>
nginx日志分割并定期删除
查看>>
Nginx日志分析系统---ElasticStack(ELK)工作笔记001
查看>>
Nginx映射本地json文件,配置解决浏览器跨域问题,提供前端get请求模拟数据
查看>>
nginx最最最详细教程来了
查看>>
Nginx服务器---正向代理
查看>>
Nginx服务器上安装SSL证书
查看>>
Nginx服务器的安装
查看>>
Nginx模块 ngx_http_limit_conn_module 限制连接数
查看>>
nginx添加模块与https支持
查看>>
Nginx用户认证
查看>>