题目描述
给出n个数字,请你求出在给出的这n个数字当中,最大的数字与次大的数字之差,最大的数字与次小的数字之差,次大的数字与次小的数字之差,次大的数字与最小的数字之差.
题目分析
首先我们需要对整个数组进行排序,排序的话是直接用快排就行,但是在排完序之后我们需要注意的是,因为数字有重复我们不能简单地直接去求,而需要去找一个第二大数和倒数第二大数,这时候就需要用到二分查找,在这里直接调用STL内置的函数就行。
方法一:利用c++的库函数
#include <bits/stdc++.h> using namespace std; const int maxn = 1e5 + 10; int a[maxn]; int main() { int n; while (~scanf("%d", &n)) { for (int i = 1; i <= n; ++i) scanf("%d", &a[i]); sort(a + 1, a + n + 1); int max2 = lower_bound(a + 1, a + n + 1, a[n]) - a - 1; int min2 = upper_bound(a + 1, a + n + 1, a[1]) - a; printf("%d %d %d %d\n", a[n] - a[max2], a[n] - a[min2], a[max2] - a[min2], a[max2] - a[1]); } }
方法二:map去重
#include <bits/stdc++.h> using namespace std; const int maxn = 1e5 + 10; int a[maxn]; map<int, int> mp; int main() { int n, x; while (~scanf("%d", &n)) { int cnt = 0; for (int i = 1; i <= n; ++i) { scanf("%d", &x); mp[x]++; if (mp[x] == 1) a[++cnt] = x; } sort(a + 1, a + cnt + 1); printf("%d %d %d %d\n", a[cnt] - a[cnt - 1], a[cnt] - a[2], a[cnt - 1] - a[2], a[cnt - 1] - a[1]); } }