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

大连seo网站网站设计公司飞沐

大连seo网站,网站设计公司飞沐,国际化网站设计,怎么制作图片文件夹目录 直接选择排序 基本思想 整体思路(升序) 单趟 多趟 代码实现 特性总结 直接选择排序 基本思想 每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的…

目录

直接选择排序

基本思想

 整体思路(升序)

单趟

多趟 

代码实现

特性总结 


直接选择排序

基本思想

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

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

相关文章:

  • 网站优化外链江西门户网站建设
  • 合肥专业网站制作设计南昌优化网站服务
  • 白宫网站 wordpress电子商务实现技术
  • 网站页面总数英文网站翻译怎么做呢
  • 建筑网站architect国家征信系统查询官网
  • 打开网站是空白页面做网站 需要买云服务器吗
  • 网站建设j基本步骤wordpress放视频播放器
  • 自己的网站怎么做seo无锡电商网站设计
  • 微信可以做网站吗长沙网站优化掌营天下
  • 网站建设归哪个部门下列不属于网站建设规划
  • 深圳网络广告推广公司seo自然排名优化
  • 做类似返利网的网站有哪些51com个人主页登陆
  • 网站not found深圳中国电信网站备案
  • 做企业网站注意些啥简单做网站的价格
  • 吴桥网站建设企业网站整站
  • 网站建设低价网站到底便宜在哪asp.ney旅游信息网站下载 简洁
  • 家纺公司网站模版wordpress 编辑器模板
  • 创建网站的流程有哪些我有服务器和模板怎么做网站
  • 快速设计网站深圳专业网站建设多少钱
  • 西安网站设计招聘郑州网站关键词优化外包
  • 网站建设水上乐园wordpress修改首页网址
  • 互联网网站建设价格智能建站模版
  • 如何访问自己建的网站江西南昌网站制作
  • 网站是什么字体天津网站建设服务好
  • 重庆长寿网站设计公司如何免费注册网址
  • 黄埔做网站公司html网页代码编辑器
  • 大鼠引物在线设计网站莱芜搜狗推广哪家好
  • 辽宁营商环境建设局网站软件园做网站
  • html和php做网站哪个好将网站加入小程序
  • 这几年做啥网站致富自助建网站工具