This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
//#pragma GCC optimize("unroll-loops")
//#pragma GCC optimize("-O3")
//#pragma GCC optimize("Ofast")
#define F first
#define S second
#define sz(x) int(x.size())
#define pb push_back
#define N 200005
#define M ll(1e9 + 7)
#define inf 1e9 + 1e9
using namespace std;
typedef long double ld;
typedef long long ll;
typedef short int si;
vector <int> X;
void del(vector <int> &v )
{
sort(v.begin(), v.end());
v.resize(unique(v.begin(), v.end()) - v.begin());
}
struct st{
vector <int> g, fn;
st() : g(0), fn(0) {}
void upd(int y)
{
y = lower_bound(g.begin(), g.end(), y) - g.begin();
for (; y < sz(g); y = (y | (y + 1))) fn[y]++;
}
void updr(int y)
{
y = lower_bound(g.begin(), g.end(), y) - g.begin();
for (; y < sz(g); y = (y | (y + 1))) fn[y]++;
}
void bld()
{
del(g);
fn.resize(sz(g));
}
int sm(int y)
{
int ans = 0;
y = upper_bound(g.begin(), g.end(), y) - g.begin() - 1;
for (; y >= 0; y = (y & (y + 1)) - 1) ans += fn[y];
return ans;
}
};
st t[N];
vector <pair <int, int> > kr[N];
int calc(int xl, int yl, int xr, int yr)
{
int ans = 0;
int v = lower_bound(X.begin(), X.end(), xr) - X.begin();
for (; v >= 0; v = (v & (v + 1)) - 1) ans += t[v].sm(yr);
v = upper_bound(X.begin(), X.end(), xl - 1) - X.begin() - 1;
for (; v >= 0; v = (v & (v + 1)) - 1) ans += t[v].sm(yl - 1);
v = upper_bound(X.begin(), X.end(), xl - 1) - X.begin() - 1;
for (; v >= 0; v = (v & (v + 1)) - 1) ans -= t[v].sm(yr);
v = lower_bound(X.begin(), X.end(), xr) - X.begin();
for (; v >= 0; v = (v & (v + 1)) - 1) ans -= t[v].sm(yl - 1);
return ans;
}
int main()
{
// freopen("input.txt", "r", stdin);// freopen("output.txt", "w", stdout);
ios_base::sync_with_stdio(0); istream::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int n, q;
cin >> n >> q;
int xl[n], yl[n], xr[n], yr[n];
for (int i = 0; i < n; i++)
{
cin >> xl[i] >> yl[i] >> xr[i] >> yr[i];
X.pb(xl[i]);
X.pb(xr[i]);
}
vector <int> g; g.clear();
int x[q], y[q], c[q];
for (int i = 0; i < q; i++)
{
cin >> x[i] >> y[i] >> c[i];
X.pb(x[i]);
kr[c[i]].pb({x[i], y[i]});
if (sz(kr[c[i]]) == 2) g.pb(c[i]);
}
X.pb(-1e9);
X.pb(1e9 + 1e9);
del(X);
for (int i = 0; i < n; i++)
{
int v = lower_bound(X.begin(), X.end(), xl[i]) - X.begin();
for (; v < sz(X); v = (v | (v + 1))) {t[v].g.pb(yl[i]); t[v].g.pb(yr[i]);}
v = lower_bound(X.begin(), X.end(), xr[i]) - X.begin();
for (; v < sz(X); v = (v | (v + 1))) {t[v].g.pb(yl[i]); t[v].g.pb(yr[i]);}
}
for (int i = 0; i < q; i++)
{
int v = lower_bound(X.begin(), X.end(), x[i]) - X.begin();
for (; v < sz(X); v = (v | (v + 1))) t[v].g.pb(y[i]);
}
for (int i = 0; i < sz(X); i++) t[i].bld();
for (int i = 0; i < q; i++)
{
int v = lower_bound(X.begin(), X.end(), x[i]) - X.begin();
for (; v < sz(X); v = (v | (v + 1))) t[v].upd(y[i]);
}
for (int i = 0; i < n; i++)
{
int ans = calc(xl[i], yl[i], xr[i], yr[i]), mns = 0;
for (auto it : g)
{
for (auto itr : kr[it])
{
int v = lower_bound(X.begin(), X.end(), itr.F) - X.begin();
for (; v < sz(X); v = (v | (v + 1))) t[v].upd(itr.S);
}
int nw = calc(xl[i], yl[i], xr[i], yr[i]) - mns;
int ost = nw - ans - 1;
mns += ost;
ans -= ost;
for (auto itr : kr[it])
{
int v = lower_bound(X.begin(), X.end(), itr.F) - X.begin();
for (; v < sz(X); v = (v | (v + 1))) t[v].updr(itr.S);
}
}
cout << ans << '\n';
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |