解法
map 启动!
这道题 n 有 2e5 暴力 n^2 会炸时间;ai 有 1e9 用桶也会炸空间。于是乎,只能用 map。
我们储存每一个数的数量,修改时,把这个数减一,如果这个数没了,那么就将记录数字种类的变量 cnt 减一,最后把增加后的数加一就行了。
代码
#include <bits/stdc++.h>
using namespace std;
long long n, a[200005], t, cnt = 1;
unordered_map<long long, int> mp;
int main() {
cin >> n >> t;
mp[0] = n;
while (t--) {
int a1, b1;
cin >> a1 >> b1;
if (mp[a[a1]] == 1)
cnt--;
mp[a[a1]]--;
a[a1] += b1;
mp[a[a1]]++;
if (mp[a[a1]] == 1)
cnt++;
cout << cnt << endl;
}
return 0;
}
作者:xyzcoolplayer 创建时间:2024-03-05 15:21:54