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

githup网站建设北京展览馆网站建设

githup网站建设,北京展览馆网站建设,建设网站成本预算,做视频网站视频用什么插件目录 直接选择排序 基本思想 整体思路(升序) 单趟 多趟 代码实现 特性总结 直接选择排序 基本思想 每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的…

目录

直接选择排序

基本思想

 整体思路(升序)

单趟

多趟 

代码实现

特性总结 


直接选择排序

基本思想

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

  • 在元素集合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/323899/

相关文章:

  • 淘宝客如何做返积分制网站衣柜做网站的关键词
  • 金山集团网站建设云优化软件
  • 网站如何进行建设千图网网站怎么做
  • 陕煤建设集团韩城分公司网站注册公司网址
  • 深圳建网站哪家公司好wordpress安装数据库错误
  • 校园网站建设er模型前端工程师是做网站
  • wordpress教程下载网站主题电子商务系统的组成
  • wcf网站开发坡头网站开发公司
  • 怎么创办自己的网站ssh jsp做网站
  • it彩票网站建设维护工程师wordpress 响应分页
  • 车险网站模版小说阅读网站系统模板下载
  • 找施工员在哪个网站上找群晖wordpress域名
  • 提高网站速度用虚拟机做网站的心得体会
  • 新竹自助建站系统知名企业愿景
  • 做网站维护的收入怎么确认成立公司注意事项
  • 重庆网站模板建站做网站全屏图片拉长代码
  • 建设银行 公户 该网站使用过期的网页设计心得体会报告
  • 销售网站建设公司凯里网站建设哪家好
  • 创建iis网站网站前端设计是什么意思
  • 做校园文化的网站asp.net p2p网站开发
  • 做网站一定要正版系统吗东莞小程序建设
  • 百度网站优化排名wordpress上传apk
  • 网站建立的重要性网站建设与管理适合男的还是女的
  • 金华做公司网站桂平市住房和城乡建设局门户网站
  • 网络公司除了建网站电子商务网站建设与维护实训报告
  • 济南网站建设专业公司企业网站开发韵茵建站
  • 昌平做网站建立网站的步骤 实湖南岚鸿
  • 建设网站带后台管理网络管理平台系统
  • 泰安网站开发网站 模板
  • 网站开发维护需要哪些岗位暴走漫画网站建设中模板