PassThePAT


  • 首页

  • 标签

  • 分类

  • 归档

  • 搜索

1108 Finding Average

发表于 2020-06-01

1107 Social Clusters

发表于 2020-06-01

1106 Lowest Price in Supply Chain

发表于 2020-06-01

1105 Spiral Matrix

发表于 2020-06-01

1104 Sum of Number Segments

发表于 2020-06-01

1103 Integer Factorization

发表于 2020-06-01

1102 Invert a Binary Tree

发表于 2020-06-01

1101 Quick Sort

发表于 2020-06-01

输入n个不同的数字,问有几个可以当快速排序的分割点pivot。输出个数以及是哪几个数字。左边要么没有要么都比pivot小,右边要么没有要么比pivot大。(题目中已经保证所有输入数字都不同)
pivot的位置与排序后的位置一致。(左小右大,分别排序左右即可,它不用动)并且要求pivot比左边最大的还大,比右边最小的还小。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#include <bits/stdc++.h>
using namespace std;

int res[100010];

int main() {
int n, cnt = 0, max = -1;
scanf("%d", &n);
vector<int> a(n), b(n);
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
b[i] = a[i];
}
sort(a.begin(), a.end());
for (int i = 0; i < n; i++) {
if (a[i] == b[i] && b[i] > max) {
res[cnt++] = b[i];
}
if (b[i] > max) {
max = b[i];
}
}
printf("%d\n", cnt);
for (int i = 0; i < cnt; i++) {
if (i != 0) printf(" ");
printf("%d", res[i]);
}
printf("\n"); // 不加这个部分会出错

return 0;
}

5
1 3 2 4 5

3
1 4 5

1100 Mars Numbers

发表于 2020-05-31

1099 Build A Binary Search Tree

发表于 2020-05-31
1…567…16

e5

158 日志
5 标签
© 2022 e5
由 Hexo 强力驱动
|
主题 — NexT.Mist v5.1.4