找快速排序的枢轴。。就是比左边的最大值要打,比右边的最小值要小。
直接遍历三遍就好啦。
#include <iostream>
#include <vector>
#include <climits>
#include <cstring>
#define MAX 100010
using namespace std;
int n;
int list[MAX];
int isPivot[MAX];
int pmin = INT_MAX, pmax = -1;
int main() {
cin >> n;
for (int i = 0; i < n; i++) {
cin >> list[i];
if (pmax < list[i])
pmax = list[i];
if (list[i] >= pmax)
isPivot[i] = 1;
}
for (int i = n - 1; i >= 0; i--) {
if (pmin > list[i]) {
pmin = list[i];
}
if (list[i] <= pmin && isPivot[i] == 1) {
isPivot[i] = 2;
}
}
vector <int> ans;
for (int i = 0; i < n; i++) {
if (isPivot[i] == 2) {
ans.push_back(list[i]);
}
}
if (ans.size() == 0) {
cout << ans.size() << endl;
cout << endl;
}
else {
cout << ans.size() << endl;
cout << ans[0];
for (int i = 1; i < ans.size(); i++) {
cout << " " << ans[i];
}
cout << endl;
}
return 0;
}
本文介绍了一种通过遍历三次数组来寻找快速排序枢轴的方法。该方法首先确定数组中的最大值和最小值,然后找到那些大于最大值且小于最小值的元素作为枢轴。
557

被折叠的 条评论
为什么被折叠?



