stl排序总结
更新时间:2023-10-21 07:26:01 阅读量: 综合文库 文档下载
学习网站:http://www.stlchina.org/twiki/bin/view.pl/Main/STLTechArticles http://www.stlchina.org/twiki/bin/view.pl/Main/STLSortAlgorithms
排序(sort):所有sort算法介绍:使用的迭代器(iterator)都需是随机迭代器(RadomAccessIterator)
1. 所有STL sort算法函数的名字列表: 函数名 sort stable_sort partial_sort partial_sort_copy nth_element is_sorted partition stable_partition 2. 比较函数:当你需要按照某种特定方式进行排序时,你需要给sort指定比较函数,否则程序会自动提供给你一个比较函数。 vector < int > vect; //...
sort(vect.begin(), vect.end()); //此时相当于调用
sort(vect.begin(), vect.end(), less
不能直接写入仿函数的名字,而是要写其重载的()函数: less
当你的容器中元素时一些标准类型(int float char)或者string时,你可以直接使用这些函数模板。但如果你
时自己定义的类型或者你需要按照其他方式排序,你可以有两种方法来达到效果:一种是自己写比较函数。另一种是重载类型的'<'操作赋。如: bool less_second(const myclass & m1, const myclass & m2) { return m1.second < m2.second; }
3. 全排序:全排序即把所给定范围所有的元素按照大小关系顺序排列。sort采用的是成熟的\快速排序算法\目前大部分STL版本已经不是采用简单的快速排序,而是结合内插排序
算法)。复杂度为n*log(n).stable_sort采用的是\归并排序\,分派足够内存是,其算法复杂度为n*log(n), 否则其复杂度为n*log(n)*log(n),其优点是会保持相等元素之间的相对位置在排序前后保持一致。 用于全排序的函数有:
void sort(RandomAccessIterator first, RandomAccessIterator last);
void sort(RandomAccessIterator first, RandomAccessIterator last,StrictWeakOrdering comp); void stable_sort(RandomAccessIterator first, RandomAccessIterator last);
void stable_sort(RandomAccessIterator first, RandomAccessIterator last, StrictWeakOrdering comp);
4. 局部排序:partial_sort采用的堆排序(heapsort),它在任何情况下的复杂度都是n*log(n).
局部排序其实是为了减少不必要的操作而提供的排序方式。 其函数原型为: 1) void partial_sort(RandomAccessIterator first, RandomAccessIterator middle,RandomAccessIterator last);
2) void partial_sort(RandomAccessIterator first,RandomAccessIterator middle, RandomAccessIterator last, StrictWeakOrdering comp);
3) RandomAccessIterator partial_sort_copy(InputIterator first, InputIterator last, RandomAccessIterator result_first,RandomAccessIterator result_last);
4) RandomAccessIterator partial_sort_copy(InputIterator first, InputIterator last,
RandomAccessIterator result_first,RandomAccessIterator result_last, Compare comp); 用法使用情况:班上有1000个学生,我想知道分数最低的5名是哪些人。 partial_sort(vect.begin(), vect.begin()+5, vect.end(),less
StrictWeakOrdering comp);
使用情况:班上有1000个学生,我想知道分数排在倒数第4名的学生。 nth_element(vect.begin(), vect.begin()+3, vect.end(),less
6. partition 和stable_partition :partition就是把一个区间中的元素按照某个条件分成两类,并没有排序。
其函数原型为:
ForwardIterator partition(ForwardIterator first, ForwardIterator last, Predicate pred)
ForwardIterator stable_partition(ForwardIterator first, ForwardIterator last, Predicate pred); 用法如:班上10个学生,计算所有没有及格(低于60分)的学生: student exam(\
stable_partition(vect.begin(), vect.end(), bind2nd(less
stable_partition nth_element
partial_sort sort
stable_sort
8. Effective STL对如何选择排序函数总结的很好:
1) 若需对vector, string, deque, 或 array容器进行全排序,你可选择sort或stable_sort;
若只需对vector, string, deque, 或 array容器中取得top n的元素,部分排序partial_sort是首选.
若对于vector, string, deque, 或array容器,你需要找到第n个位置的元素或者你需要得到top n且不关系top
2) n中的内部顺序,nth_element是最理想的;
3) 若你需要从标准序列容器或者array中把满足某个条件或者不满足某个条件的元素分开,你最好使用partition或stable_partition;
4) 若使用的list容器,你可以直接使用partition和stable_partition算法,你可以使用list::sort代替sort和stable_sort排序。若你需要得到partial_sort或nth_element的排序效果,你必须间接使用。
声明:JavaEye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
正在阅读:
stl排序总结10-21
2014版大型船用柴油机项目(立项及贷款用)可行性研究报告编制机构服务流程及案例展示05-19
汽车零部件标准符合性评估系统设计说明书09-30
浅析余秋雨历史文化散文的特色11-22
加油站投诉处理办法03-21
鞋厂安全生产管理制度汇编09-22
张玉利:创业管理讲座05-06
游泳馆会员管理系统09-24
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 排序
- 总结
- stl
- 最全的万能表的使用方法
- 2018年中国工业自动控制系统装置制造行业现状分析与发展趋势研究报告目录
- 基于图像预处理的二维码识别技术的研究
- 墓志铭 - 图文
- 编译原理及实现课后习题答案绝杀版
- 中国现当代文学题现代部分
- 西安交通大学计算方法上机作业
- 预应力空心板梁台座设计
- 高中教师继续教育培训班学员面授须知
- 毕业设计说明书 悬浮聚合法年产 30 万吨聚氯乙烯 车间工艺设计
- 行业用水定额
- 人音版高中音乐教材分析
- 甜瓜高产栽培技术 2
- 房地产投资项目经济评价
- 统编本二年级语文下册字词句练习题
- 人教版一年级上册数学第一单元试卷
- 苏俄空地(面)导弹 - 图文
- 电大专科法学《宪法学》试题及答案1
- 第二章 中国自然旅游资源
- 政府采购考试复习题(一)