当前位置: 首页 > news >正文

江苏建设工程交易信息网站科技馆网站建设方案

江苏建设工程交易信息网站,科技馆网站建设方案,网站建设需要哪些软件,如何做自己的电影网站目录 直接选择排序 基本思想 整体思路(升序) 单趟 多趟 代码实现 特性总结 直接选择排序 基本思想 每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的…

目录

直接选择排序

基本思想

 整体思路(升序)

单趟

多趟 

代码实现

特性总结 


直接选择排序

基本思想

每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完 。

  • 在元素集合array[i]--array[n-1]中选择关键码最大(小)的数据元素。
  • 若它不是这组元素中的最后一个(第一个)元素,则将它与这组元素中的最后一个(第一个)元素交换。
  • 在剩余的array[i]--array[n-2](array[i+1]--array[n-1])集合中,重复上述步骤,直到集合剩余1个元素。

直接选择排序是暴力选数值。

堆排序是在堆的结构上选数值。

👇一个一个找最小的值 

而我们要实现的是,最小的和最大的一起找,最小的放到最前面,最大的放到最后面。 

 整体思路(升序)

  • 在元素集合array[i]--array[n-1]中选择关键码最小的数据元素。
  • 若它不是这组元素中的第一个元素,则将它与这组元素中的第一个元素交换。
  • 在剩余的array[i]--array[n-2](array[i+1]--array[n-1])集合中,重复上述步骤,直到集合剩余1个元素。
  • 最大的数的下标:maxi   最小的数的下标:mini
  • 最大的数的位置的下标:begin = 0
  • 最小的数的位置的下标:end = n-1
  • 选出元素下标和对应位置的下标,的元素交换,不是覆盖❗
  • 重复上诉过程,然后begin-- / end++ 直到它们相遇(begin < end )

单趟

【注意】 

  • ❗注意这里交换的是数值,下标没有交换🆗也就是说交换完之后maxi&mini任然指向原来的位置

试想,如果第一个数就是最大的呢?这样的话,maxi就是0,当Swap(&a[mini], &a[begin]);后,如图。那么如果我们接下来实行Swap(&a[maxi], &a[end]);就会把1和7交换,这样就错了!

  • 最大值元素的下标maxi可能与begin下标重叠

多趟 

单趟结束后,我们需要让begin++,end--,以便下一趟的开始。下一趟我们要比较的就是中间的数。 依次往下,直到begin和end相遇结束。

代码实现

void SelectSort(int* a, int n)
{int begin = 0, end = n - 1;while (begin < end){int mini = begin, maxi = begin;for (int i = begin + 1; i <= end; ++i){if (a[i] < a[mini]){mini = i;}if (a[i] > a[maxi]){maxi = i;}}Swap(&a[begin], &a[mini]);if (maxi == begin){maxi = mini;}Swap(&a[end], &a[maxi]);++begin;--end;}
}

特性总结 

1. 直接选择排序思考非常好理解,但是效率不是很好。实际中很少使用
2. 时间复杂度:O(N^2)

  • 最好的情况也是O(N^2),因为我们并不知道他是否有序。

3. 空间复杂度:O(1)
4. 稳定性:不稳定
 

http://www.yayakq.cn/news/916545/

相关文章:

  • 怎么做扒代码网站濮阳网站建设熊掌网络
  • 企业自有网站北京天奕时代创意设计有限公司
  • 建设厅证书查询网站石家庄网络关键词排名
  • 做网站jw100网站访问流程设计
  • 专业app制作平台seo关键词首页排名代发
  • 公司网站建设文案做网站用别人的源码可以吗
  • 攸县网站建设网站开发项目报价方案
  • 贵州省建设厅考试网站哈尔滨学网页设计
  • 如何做购物网站的后台官网推广方法有哪些
  • 怎么找做网站的公司山西cms建站系统价格
  • 西安网站建设公司西安网络公司广西南宁网站优化
  • 免费的图库网站网站建设中的pv指的是啥
  • 做网站用cms好吗wordpress固定连接怎么设置最好
  • 网站建设中的功能模块描述招聘平台哪个好用
  • 音乐网站设计源码做企业网站公司报价
  • 做网站需要关注哪些重要问题大兴区住房与城乡建设部网站
  • 西湖区外贸网站建设灰色词seo推广
  • linux建设网站php打开提示404网易那个网站可以做字幕
  • 个人做网站开发外贸英文网站开发
  • 欢迎访问陕西省交通建设集团公司网站重庆长寿网站设计公司哪家专业
  • 如何做网站地图txt建设通网站原理
  • 顺德营销网站设计青岛关键词快速排名
  • python做网站教程9377网页游戏排行榜
  • 广州城市建设网站做网站还赚钱吗
  • 天津河东做网站贵吗新手搭建论坛己做网站
  • 免费网站建站平台常熟做网站
  • 如何管理建好的网站物联网工程主要学什么
  • 南宁电商网站建设小程序定制语言
  • 分类信息系统网站模板怎么看网站建设时间
  • 建筑装饰和网站建设哪个好做那种英文网站有流量