algorithm库介绍之---- stable_sort()方法 与 sort()方法

关于stable_sort()和sort()的区别:

你发现有sort和stable_sort,还有 partition 和stable_partition, 感到奇怪吧。其中的区别是,带有stable的函数可保证相等元素的原本相对次序在排序后保持不变。或许你会问,既然相等,你还管他相对位置呢,也分不清 楚谁是谁了?这里需要弄清楚一个问题,这里的相等,是指你提供的函数表示两个元素相等,并不一定是一摸一样的元素。

例如,如果你写一个比较函数:

boolless_len(conststring &str1,conststring &str2)

{

return str1.length() < str2.length();

}

此时,"apple" 和 "winter" 就是相等的,如果在"apple" 出现在"winter"前面,用带stable的函数排序后,他们的次序一定不变,如果你使用的是不带"stable"的函数排序,那么排序完 后,"Winter"有可能在"apple"的前面。

举例说明:

[cpp]view plaincopy

结果:


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 5,464评论 0 3
  • 排序算法 按照是否将元素放入到内存中,排序分为内部排序和外部排序。内部排序适合元素不多的文件,按照元素的排序原则,...
    DevKyle阅读 4,878评论 0 49
  • 第1章 第一个C程序第2章 C语言基础第3章 变量和数据类型第4章 顺序结构程序设计第5章 条件结构程序设计第6章...
    小狮子365阅读 13,657评论 3 71
  • STL中一些算法的总结 1.函数的名字列表: sort 对给定区间所有元素进行排序stable_sort 对给定区...
    狗蛋同学阅读 1,351评论 0 0
  • 体内思路:这是一个贪心算法,每次从森林中选取权值最小的两个数,较大的做为左孩子,较小的做为右孩子,生成一个新的根,...
    IT孤独者阅读 8,718评论 0 0

友情链接更多精彩内容