c++ sort与stable_sort的区别与自定义排序的使用

16 篇文章 0 订阅

sort的实现是基于快速排序的,快速排序在比较算法中算是速度最快的,平均的时间复杂度为O(nlogn),虽然它的最差时间复杂度可能达到O(n2)。

stable_sort的实现是基于归并排序的,它的时间复杂度为O(nlogn),一般情况下,它比快速排序稍慢。但是它是一种稳定排序,所谓稳定排序,就是说相同大小的元素,在排序前后的相对位置不会发生改变。即相同大小的元素中,原来在前的元素,排序之后还是在前面。

它们使用时都需要#include<algorithm>

不过你可能会有疑问,既然是一样的元素,为何我们还有管谁前谁后?因为这里我们所说的一样,是指在比较的时候大小一样,并不一定就是说这两个元素完全一样,比如我们有时候会自定义比较函数:

//我们按对组的第一个元素大小对对组进行排序
bool cmp(pair<int, char> a, pair<int, char> b)
{
	return (a.first>b.first);//>表示从大到小,<表示从小到大(注意这里return 0是不移动元素,return 1是移动元素,
        //也就是说a.first==b.first时return 0不改变原来的顺序,vs中相等情况必须返回0)
}


int main()
{
	vector<pair<int, char>>v;
	v.push_back(make_pair(1, 'a'));
	v.push_back(make_pair(1, 'b'));
	v.push_back(make_pair(2, 'a'));
	v.push_back(make_pair(3, 'a'));
	
	stable_sort(v.begin(),v.end(),cmp);
	for (auto x : v)
	{
		cout << x.first << " " << x.second<<endl;
	}
	
}

输出为:

 

 

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中,stable_sort是一种稳定排序算法,它基于归并排序实现。稳定排序意味着排序后元素之间的相对位置不会发生变化。stable_sort适用于对比较复杂的数据进行排序,比如订单数据中已经按照订单号排好了,现在想对交易日期再进行排序stable_sort的时间复杂度为O(NlogN),空间复杂度为O(N)。\[2\] 在STL中,stable_sort的实现实际上就是归并排序。然而,由于归并排序需要额外的数组来执行归并操作,所以如果没有足够的空间,就无法正常进行归并。STL中的stable_sort通过开辟一个缓冲数组来解决这个问题。如果开辟缓冲数组失败,就会调用内部的inplace_stable_sort函数进行排序;如果有足够的空间,就会执行归并操作。\[1\] 另外,STL中的归并排序在底层使用了插入排序。它先调用chunk_insertion_sort函数对每个长度为chunk_size的子区间进行插入排序,然后再进行归并操作。\[3\] 总结起来,C++stable_sort是一种稳定排序算法,基于归并排序实现。它适用于对比较复杂的数据进行排序,时间复杂度为O(NlogN),空间复杂度为O(N)。在STL中,stable_sort的实现使用了缓冲数组和插入排序。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *3* [C++编程之stable_sort](https://blog.csdn.net/sinat_22336563/article/details/72630655)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [C++stable_sortsort学习及简单实现](https://blog.csdn.net/u012328476/article/details/124975509)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值