1101. Quick Sort (25)

原创 2015年11月20日 21:33:18

1.这道题目需要考虑采用适当的数据结构,即小根堆和大根堆

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)

N个数 对于这N个数,那些左边都小于等于它,右边都大于等于它的是属于要输出的,进入ans中 ans排好序从小到大 输出ans中有几个数+换行 输出ans[0] ans[1]……+换行(PS即使没有数也...
  • u014646950
  • u014646950
  • 2015年09月12日 21:10
  • 1058

1101. Quick Sort (25)解题报告

先建一个表记录每一个下标及其左边最大的元素,再建一个表记录每一个下标及其右边最小的元素。 如果一个元素比左边所有的元素大,比右边所有的元素小,那么它就是一个枢轴。 #define _CRT...
  • chr1991
  • chr1991
  • 2016年12月30日 14:15
  • 114

PAT-A 1101. Quick Sort (25)

打表+递推 减小时间复杂度
  • Daniel960601
  • Daniel960601
  • 2017年03月20日 16:24
  • 180

PAT_A 1101. Quick Sort (25)

PAT-A-1101. Quick Sort (25)注意输出为0,第二行为空,需要输出一个回车
  • scylhy
  • scylhy
  • 2016年10月20日 23:18
  • 253

【PAT】1101. Quick Sort (25)

There is a classical process named partition in the famous quick sort algorithm. In this process we ...
  • realxuejin
  • realxuejin
  • 2015年10月21日 19:09
  • 739

solution Of 1101. Quick Sort (25)

1101. Quick Sort (25)There is a classical process named partition in the famous quick sort algorithm...
  • qq_30490125
  • qq_30490125
  • 2016年06月16日 00:01
  • 301

1101. Quick Sort (25)[快排]

1. 原题:https://www.patest.cn/contests/pat-a-practise/1101 2. 思路: 题意:判断序列中的哪些数可以作为中枢点。排序题。考察快排。 思路:...
  • shepherd2010
  • shepherd2010
  • 2017年05月09日 15:48
  • 69

PAT 1101. Quick Sort (25)

第一次参加PAT考试,遇到的第二道题,感觉很简单,但是智商余额不足,导致最后只想出来遍历的方法,还有一个陷阱是如果数据为0也要输出一个空行。最笨的方法也能得20分,只能说真给面子了。 看了大神们的代...
  • u010980446
  • u010980446
  • 2015年09月21日 11:21
  • 788

pat 1101. Quick Sort (25)

时间限制 200 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作...
  • chen1007124127
  • chen1007124127
  • 2016年05月07日 10:07
  • 78

[PAT]1101. Quick Sort (25)

#include #include #include #include #include #include #include #include #include using name...
  • rjq235
  • rjq235
  • 2015年10月01日 09:54
  • 312
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:1101. Quick Sort (25)
举报原因:
原因补充:

(最多只允许输入30个字)