1490F Equalize the Array
发表于:2021-02-19 | 分类: CF

Equalize the Array

The question

CF 1490F Q.png

Input & Output

CF 1490F S.png

Simplify the question

We’re supposed to delete minimum number of elements to make the given array beautiful, which means every number in the array appears same times

Solve

First, we will save the array to a map. Since we will do a sort, which can’t be done with map, I created a vector of pair

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
ll a[maxn];
map<ll, int> mp;
vector<pair<int, int>> b;

bool cmp(pair<int, int> x, pair<int, int> y) {
return x.second > y.second;
}

for (int i = 0; i < n; i++) {
cin >> a[i];
mp[a[i]]++;
}
for (auto it:mp) {
b.emplace_back(it.first, it.second);
}
sort(b.begin(), b.end(), cmp);

The next step is the key. We sorted the vector with the number of elements in decreasing order.

b[i].second*(i+1) means the number of elements will be left, so n-b[i].second*(i+1) will be the number of elements we will delete(for this one).

Then we just find the minimum one and output

1
2
3
4
int ans = inf;
for (int i = 0; i < b.size(); i++) {
ans = min(ans, n - b[i].second * (i + 1));
}

Code

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
38
39
40
41
42
43
44
45
46
47
48
#include<bits/stdc++.h>

using namespace std;

const int maxn = 2e5 + 5;
const int inf = INT_MAX;
const int mod = 1e9 + 7;

typedef long long ll;

ll a[maxn];
map<ll, int> mp;
vector<pair<int, int>> b;

bool cmp(pair<int, int> x, pair<int, int> y) {
return x.second > y.second;
}

void solve() {
int n;
cin >> n;
b.clear();
mp.clear();
for (int i = 0; i < n; i++) {
cin >> a[i];
mp[a[i]]++;
}
for (auto it:mp) {
b.emplace_back(it.first, it.second);
}
sort(b.begin(), b.end(), cmp);
int ans = inf;
for (int i = 0; i < b.size(); i++) {
ans = min(ans, n - b[i].second * (i + 1));
}
cout << ans << endl;
}

int main() {
ios::sync_with_stdio(false);
int t;
cin >> t;
while (t--) {
solve();
}

return 0;
}
上一篇:
1486B Eastern Exhibition
下一篇:
my first blog