1101. Quick Sort (25)
2015-11-20 21:33
393 查看
1.这道题目需要考虑采用适当的数据结构,即小根堆和大根堆
2.判断某个元素是否能够成为pivot,那么该元素左边数组应该构成一个大根堆,堆顶元素应该小于该元素,该元素的右边构成小根堆,堆顶元素大于该元素
3.左边的小根堆,一直插入即可,利用priority_queue,而右边则需要进行维护,需要编写仿函数
4右边的大根堆维护机制:建立哈希表times,记录每个元素出现的次数,每往后检测新元素数,把新元素出现的次数-1,同时检测大根堆的堆顶元素,如果出现次数为0则弹出,直至剩下出现次数不为0的堆顶
AC代码如下:
2.判断某个元素是否能够成为pivot,那么该元素左边数组应该构成一个大根堆,堆顶元素应该小于该元素,该元素的右边构成小根堆,堆顶元素大于该元素
3.左边的小根堆,一直插入即可,利用priority_queue,而右边则需要进行维护,需要编写仿函数
4右边的大根堆维护机制:建立哈希表times,记录每个元素出现的次数,每往后检测新元素数,把新元素出现的次数-1,同时检测大根堆的堆顶元素,如果出现次数为0则弹出,直至剩下出现次数不为0的堆顶
AC代码如下:
//#include<string> //#include <iomanip> #include<vector> #include <algorithm> //#include<stack> #include<set> #include<queue> #include<map> //#include<unordered_set> #include<unordered_map> //#include <sstream> //#include "func.h" //#include <list> #include<stdio.h> #include<iostream> #include<string> #include<memory.h> #include<limits.h> using namespace std; struct cmp { bool operator()(const int&a, const int&b) { return a > b; } }; int main(void) { int sum; cin >> sum; int *num = new int[sum]; map<int, int> times; /*vector<int> times(100001, 0);*/ priority_queue<int> lq; priority_queue<int,vector<int>,cmp> rq; for (int i = 0; i < sum; i++) { scanf("%d", &num[i]); times[num[i]]++; rq.push(num[i]); } vector<int> ans(0); for (int i = 0; i < sum; i++) { if (i>0) lq.push(num[i - 1]); if (rq.size() != 0) {//如果右边heap不为空 times[num[i]]--;//减少num[i]的次数,以维护右边的小根堆 while (rq.size() != 0 && times[rq.top()] == 0) rq.pop();//检测堆顶元素,出现次数是否为0,如果为0,证明应该被弹出, if (rq.size() != 0 && num[i]>rq.top()) { continue; } } if (lq.size() != 0 && num[i] < lq.top()) { continue; } ans.push_back(num[i]); } cout << ans.size() << endl; sort(ans.begin(), ans.end()); for (int i = 0; i < ans.size(); i++) { printf("%d", ans[i]); if (i != ans.size() - 1) cout << " "; } cout << endl;//注意在后面添加换行 return 0; }
相关文章推荐
- 1101. Quick Sort (25)
- hdoj2767Proving Equivalences【scc+缩点】
- 独立使用UEditor编辑器图片和文件上传(调用内置第三方插件swfupload)
- iOS开发系列-- UIScrollView
- IOS之UI--自定义按钮实现代理监听点击事件
- PyQt4(使用ui)
- 注解(浅谈Dagger,ButterKnife,Roboguide)
- APUE学习笔记——标准I/O
- UIDatePicker 日期滚轮)/时间选取器
- 提高Interface Builder高效工作的8个技巧
- UIImagePickerController 的部分用法详解
- leetcode-implement-queue-using-stacks
- iOS中UIMenuController的使用
- UIScrollView与UIPageControl+自动滑动的封装
- ios UILocalNotification的使用
- Qt .ui转换为.h文件
- STL容器-序列式容器deque
- Android——使用Handle和Message更新UI控件
- iOS开发中UIViewcontentMode的12种属性值
- ios的手势UIGestureRecognizer