1045. 快速排序(25)
来源:互联网 发布:南瑞信通 知乎 编辑:程序博客网 时间:2024/06/16 11:24
1045. 快速排序(25)
时间限制
200 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CAO, Peng
著名的快速排序算法里有一个经典的划分过程:我们通常采用某种方法取一个元素作为主元,通过交换,把比主元小的元素放到它的左边,比主元大的元素放到它的右边。 给定划分后的N个互不相同的正整数的排列,请问有多少个元素可能是划分前选取的主元?
例如给定N = 5, 排列是1、3、2、4、5。则:
因此,有3个元素可能是主元。
输入格式:
输入在第1行中给出一个正整数N(<= 105); 第2行是空格分隔的N个不同的正整数,每个数不超过109。
输出格式:
在第1行中输出有可能是主元的元素个数;在第2行中按递增顺序输出这些元素,其间以1个空格分隔,行末不得有多余空格。
输入样例:51 3 2 4 5输出样例:
31 4 5
还是自己太渣。。确实没想到。。排序后 如果位置不变的话 ,(此时后面的数一定是比前面大的),如果此时其大于左边的最大值的话,其一定就是主元。。
#include <stdio.h>#include <iostream>#include <stack>#include <string.h>#include <queue>#include <cmath>#include <vector>#include <algorithm>#include <map>#include <set>#include <string>using namespace std;typedef long long LL;int a[100001];int b[100001];int main() { //freopen("in.txt", "r", stdin); //freopen("out.txt","w",stdout); int num; scanf("%d", &num); //vector<int> a(num); for(int i = 0; i < num; i++){ scanf("%d", &a[i]); b[i] = a[i]; } sort(a, a + num); int ans = 0, max = 0; vector<int> v1; for(int i = 0; i < num; i++){ //当当前元素没有变化并且它左边的所有值的最大值都比它小的时候就可以认为它一定是主元 //a[i]是排序后的数组 然后如果b[i] == a[i] 证明其是位置不变, 如果b[i]大于其左边的数值 ,则可以认为一定是主元 if(a[i] == b[i] && b[i] > max){ ans++; v1.push_back(a[i]); } if(b[i] > max){ max = b[i]; } } cout << ans << endl; if(v1.size() != 0){ cout << v1[0]; }else { cout << endl; } for(int i = 1; i < v1.size(); i++){ cout << " " << v1[i] ; } return 0;}
阅读全文
0 0
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- 1045. 快速排序(25)
- js 跳出循环的三种区别备忘
- jQuery之AJAX总结
- 服务发现:Zookeeper vs etcd vs Consul
- 进程同步-管程
- Play+scala上传文件
- 1045. 快速排序(25)
- iOS 使用MFMailComposeViewController 报错及解决方案
- POJ 2417 Discrete Logging 笔记
- mysql之外键约束
- NEW RULE FOR THE NEW ECONOMY
- svn 安装与使用
- 道歉信(我和小福的故事之六)
- 剑指offer--面试题6:从头到尾打印链表
- 10063---java多线程总结五:线程池的原理及实现