My code gives runtime error for some testcases of this Problem.
My Solution
But when I add integer 0, n times in the multiset at the beginning, my code gets accepted. Why?
Added Part
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3814 |
3 | jqdai0815 | 3682 |
4 | Benq | 3529 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3517 |
7 | Radewoosh | 3410 |
8 | hos.lyric | 3399 |
9 | ecnerwala | 3392 |
9 | Um_nik | 3392 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | maomao90 | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 161 |
5 | djm03178 | 158 |
6 | -is-this-fft- | 157 |
7 | adamant | 155 |
8 | awoo | 154 |
8 | Dominater069 | 154 |
10 | luogu_official | 150 |
My code gives runtime error for some testcases of this Problem.
void solve() {
int n, x, q;
cin >> n >> x >> q;
vector<int> a(n);
for (int i = 0; i < n; i++) {
cin >> a[i];
a[i] -= i;
}
map<int, int> f;
for (int i = 0; i < x; i++) {
f[a[i]]++;
}
multiset<int, greater<int>> mt;
for (auto it : f) {
mt.insert(it.second);
}
vector<int> ans(n - x + 1);
ans[0] = x - *mt.begin();
for (int i = x; i < n; i++) {
int cur = i;
int beg = i - x;
mt.erase(mt.find(f[a[beg]]));
f[a[beg]]--;
mt.insert(f[a[beg]]);
mt.erase(mt.find(f[a[cur]]));
f[a[cur]]++;
mt.insert(f[a[cur]]);
ans[beg] = x - *mt.begin();
}
while (q--) {
int l, r;
cin >> l >> r;
cout << ans[l - 1] << "\n";
}
}
But when I add integer 0, n times in the multiset at the beginning, my code gets accepted. Why?
multiset<int, greater<int>> mt;
for(int i = 1; i <= n; i++) {
mt.insert(0);
}
Name |
---|
check if element exists before deleting
Thanks! it worked. I always thought that erase function is capable of handling such case.