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>
using namespace std;
// #pragma GCC optimize("Ofast,unroll-loops")
// #pragma GCC target("avx,avx2,fma")
#define max3(a, b, c) max(a, max(b, c))
#define min3(a, b, c) min(a, min(b, c))
#define mp make_pair
#define f first
#define se second
#define pb push_back
#define ppb pop_back
#define ll long long
#define ull unsigned long long
#define cntbit(x) __builtin_popcount(x)
#define uset unordered_set
#define umap unordered_map
#define pii pair<int, int>
#define ld long double
#define pll pair<long long, long long>
const int inf = 2e9;
const int block = 320;
const int N = 1e5 + 15;
int n, m, q, ans[N], p[N], sz[N];
struct edge {
int u, v, w;
bool operator < (const edge &b) const {
return w > b.w;
}
};
struct query {
int type, w, e, v, ind, updatesTillNow;
bool operator < (const query &b) const {
if(w == b.w) {
if(updatesTillNow == b.updatesTillNow)
return ind > b.ind;
return updatesTillNow > b.updatesTillNow;
}
return w > b.w;
}
};
edge e[N];
query qs[N];
int update[N];
bool used[N];
int find(int v) {
if(v == p[v])
return v;
return p[v] = find(p[v]);
}
inline void unio(int a, int b) {
a = find(a);
b = find(b);
if(a != b) {
if(sz[a] < sz[b])
swap(a, b);
p[b] = a;
sz[a] += sz[b];
}
}
vector <pii> g[N];
vector <query> qq, upd;
vector <edge> edges;
vector <int> was;
edge last[N], back[N];
void dfs(int v, int ind, int w) {
used[v] = true;
was.pb(v);
ans[ind] += sz[v];
for(pii to : g[v])
if(!used[to.f])
dfs(to.f, ind, w);
}
inline void getrid() {
for(auto i : upd)
used[i.e] = true;
for(int i = 1; i <= m; ++i)
if(!used[i])
edges.pb(e[i]);
for(auto i : upd)
used[i.e] = false;
}
bool usedupd[N];
inline void solve() {
edges.clear();
sort(qq.begin(), qq.end());
getrid();
sort(edges.begin(), edges.end());
vector <edge>::iterator it = edges.end();
if(!edges.empty())
it = edges.begin();
for(int i = 1; i <= n; ++i)
p[i] = i, sz[i] = 1;
for(query cur : qq) {
while(it != edges.end() && it->w >= cur.w) {
unio(it->v, it->u);
++it;
}
for(int i = cur.updatesTillNow - 1; i >= 0; --i) {
if(!usedupd[upd[i].e]) {
edge x = e[upd[i].e];
x.w = upd[i].w;
if(x.w >= cur.w) {
g[find(x.u)].pb(mp(find(x.v), x.w));
g[find(x.v)].pb(mp(find(x.u), x.w));
}
}
usedupd[upd[i].e] = true;
}
for(int i = cur.updatesTillNow; i < upd.size(); ++i) {
if(!usedupd[upd[i].e]) {
edge x = back[i];
if(x.w >= cur.w) {
g[find(x.u)].pb(mp(find(x.v), x.w));
g[find(x.v)].pb(mp(find(x.u), x.w));
}
}
usedupd[upd[i].e] = true;
}
dfs(find(cur.v), cur.ind, cur.w);
for(int i = 0; i < upd.size(); ++i)
usedupd[upd[i].e] = false;
for(int i = cur.updatesTillNow - 1; i >= 0; --i) {
if(!usedupd[upd[i].e]) {
edge x = e[upd[i].e];
x.w = upd[i].w;
if(x.w >= cur.w) {
g[find(x.u)].ppb();
g[find(x.v)].ppb();
}
}
usedupd[upd[i].e] = true;
}
for(int i = cur.updatesTillNow; i < upd.size(); ++i) {
if(!usedupd[upd[i].e]) {
edge x = back[i];
if(x.w >= cur.w) {
g[find(x.u)].ppb();
g[find(x.v)].ppb();
}
}
usedupd[upd[i].e] = true;
}
for(int i = 0; i < upd.size(); ++i)
usedupd[upd[i].e] = false;
while(!was.empty()) {
used[was.back()] = false;
was.ppb();
}
}
for(int i = 0; i < upd.size(); ++i)
e[upd[i].e].w = upd[i].w;
upd.clear();
qq.clear();
}
int main() {
scanf("%d%d", &n, &m);
for(int i = 1; i <= m; ++i) {
scanf("%d%d%d", &e[i].u, &e[i].v, &e[i].w);
last[i] = e[i];
}
scanf("%d", &q);
for(int i = 1; i <= q; ++i) {
scanf("%d", &qs[i].type);
qs[i].ind = i;
if(qs[i].type == 1) {
scanf("%d%d", &qs[i].e, &qs[i].w);
back[upd.size()] = last[qs[i].e];
last[qs[i].e] = e[qs[i].e];
last[qs[i].e].w = qs[i].w;
upd.pb(qs[i]);
}
else {
scanf("%d%d", &qs[i].v, &qs[i].w);
qs[i].updatesTillNow = upd.size();
qq.pb(qs[i]);
}
if(i % block == 0)
solve();
}
solve();
for(int i = 1; i <= q; ++i)
if(ans[i])
printf("%d\n", ans[i]);
return 0;
}
Compilation message (stderr)
bridges.cpp: In function 'void solve()':
bridges.cpp:123:37: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = cur.updatesTillNow; i < upd.size(); ++i) {
~~^~~~~~~~~~~~
bridges.cpp:136:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < upd.size(); ++i)
~~^~~~~~~~~~~~
bridges.cpp:150:37: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = cur.updatesTillNow; i < upd.size(); ++i) {
~~^~~~~~~~~~~~
bridges.cpp:161:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < upd.size(); ++i)
~~^~~~~~~~~~~~
bridges.cpp:169:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i = 0; i < upd.size(); ++i)
~~^~~~~~~~~~~~
bridges.cpp: In function 'int main()':
bridges.cpp:176:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d%d", &n, &m);
~~~~~^~~~~~~~~~~~~~~~
bridges.cpp:178:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d%d%d", &e[i].u, &e[i].v, &e[i].w);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
bridges.cpp:181:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d", &q);
~~~~~^~~~~~~~~~
bridges.cpp:183:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d", &qs[i].type);
~~~~~^~~~~~~~~~~~~~~~~~~
bridges.cpp:186:9: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d%d", &qs[i].e, &qs[i].w);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
bridges.cpp:193:9: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d%d", &qs[i].v, &qs[i].w);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |