STL排序之merge
来源:互联网 发布:夜访吸血鬼 结局 知乎 编辑:程序博客网 时间:2024/05/16 19:27
merge,归并排序。对象为两个已经有序(都升序或降序)序列。对于有序的处理,merge的性能要优于sort。但因对象是有序的,所以也比较少用。
废话不说,之间把pat题目的代码放这。题目链接:http://pat.zju.edu.cn/contests/pat-a-practise/1029。
merge
#include <stdio.h>#include <algorithm>#define SIZE 1000000+100using namespace std;int n, m;int a[SIZE], b[SIZE], c[SIZE*2];int main(){#ifdef ONLINE_JUDGE#elsefreopen("E:\\in.txt", "r", stdin);#endifscanf("%d", &n);int i;for(i=0; i<n; i++){scanf("%d", &a[i]);}scanf("%d", &m);for(i=0; i<m; i++){scanf("%d", &b[i]);}merge(a, a+n, b, b+m, c);printf("%d\n", c[(n+m-1)/2]);return 0;}
inplace_merge
原地merge,节省空间。空间上,从merge的O(n)变为O(1),还保留了O(nlgn)的时间优良基因。那就是inplace_merge
// 还要开辟一个数组?这么麻烦,看我的吧!#include <stdio.h>#include <vector>#include <algorithm>using namespace std;int n,m;vector<int> a;int main(){#ifdef ONLINE_JUDGE#elsefreopen("E:\\in.txt", "r", stdin);#endifscanf("%d", &n);int i, t;for(i=0; i<n; i++){scanf("%d", &t);a.push_back(t);}scanf("%d", &m);for(; i<n+m; i++){scanf("%d", &t);a.push_back(t);}inplace_merge(a.begin(), a.begin()+n, a.end());// Hi! 我在这printf("%d\n", a[(a.size()-1)/2]);return 0;}
1. http://hi.baidu.com/soulumia/item/ea32caa64f72b3f414329b75
2. http://www.cnblogs.com/music-liang/archive/2013/04/16/3023578.html#008
3. http://msdn.microsoft.com/zh-tw/library/80d2w3sc(v=vs.110).aspx
0 0
- STL排序之merge
- STL 之adjacent_find, merge,inplace_merge
- STL 之adjacent_find, merge,inplace_merge
- STL之排序算法
- STL之vetor 排序
- STL之排序
- STL之sort 排序
- STL算法之排序
- STL之list排序
- STL之排序算法
- STL中与快速排序媲美的merge sort
- STL-map之关键字排序
- STL之sort:vector排序
- stl排序之sort函数
- stl排序之sort函数
- STL之partial_sort排序学习
- STL简单应用之排序
- stl排序之sort函数
- 如何在高并发分布式系统中生成全局唯一Id
- getline函数
- ubuntu 12.04 LTS 安装配置JDK1.6.0_45
- POJ 1385 多边形的重心
- 遗传算法、贪婪算法、粒子群算法、蚂蚁算法概念简介
- STL排序之merge
- 什么事函数式编程
- imp导入IMP-00098: INTERNAL ERROR: impccr2_字符集_部分存储过程创建不了
- Java数组的使用
- Servlet生命周期与工作原理
- 第52条:通过接口引用对象
- 关于源到源实现的最新想法
- C/S结构的服务器编写习惯
- 组队赛(一)F - Low Power