이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
#define fi first
#define se second
#define pb push_back
const int N = (int)5e4 + 5, M = (int)1e5 + 5, Q = M, NGU = 320;
int n, m, q, ans[Q];
vector<int> gr[N], contain;
bool vis[N];
struct Edge {
int u, v, d;
Edge (int _u = 0, int _v = 0, int _d = 0) : u(_u), v(_v), d(_d) {}
bool operator< (const Edge &_) const { return make_pair(d, make_pair(u, v) ) > make_pair(_.d, make_pair(_.u, _.v) ); }
} edge[M], edge_[M];
set< pair<Edge, int> > setEdge;
struct Query {
int t, id, r;
Query (int _t = 0, int _id = 0, int _r = 0) : t(_t), id(_id), r(_r) {}
bool operator< (const Query &_) const { return r > _.r; }
} query[Q];
struct Dsu {
int pSet[N], szSet[N];
void init () {
for (int i = 1; i <= n; ++i) pSet[i] = i, szSet[i] = 1;
}
int findSet (int i) { return i == pSet[i] ? i : pSet[i] = findSet(pSet[i]); }
void unionSet (int i, int j) {
i = findSet(i); j = findSet(j);
if (i == j) return ;
if (szSet[i] > szSet[j]) swap(i, j);
szSet[j] += szSet[i];
pSet[i] = j;
}
} dsu;
void dfs (int u) {
if (vis[u]) return ;
vis[u] = 1; contain.pb(u);
for (int v : gr[u]) dfs(v);
}
int main () {
// freopen("test.INP", "r", stdin);
scanf("%d %d", &n, &m);
for (int i = 1; i <= m; ++i) {
int u, v, d; scanf("%d %d %d", &u, &v, &d);
edge_[i] = edge[i] = Edge(u, v, d);
setEdge.insert( { edge[i], i } );
}
scanf("%d", &q);
for (int i = 1; i <= q; ++i) {
int t, id, r; scanf("%d %d %d", &t, &id, &r);
query[i] = Query(t, id, r);
}
for (int i = 1; i <= q; i += NGU) {
dsu.init();
vector< pair<Query, int> > vec;
vector<bool> exist(M);
for (int j = i; j <= min(q, i + NGU - 1); ++j) {
if (query[j].t == 2) vec.pb( { query[j], j } );
else exist[ query[j].id ] = 1;
}
sort(vec.begin(), vec.end() );
vector<Edge> e;
for (auto _ : setEdge) if (!exist[_.se]) e.pb(_.fi);
int iE = 0;
for (auto _ : vec) {
Query _query = _.fi;
for (; iE < (int)e.size() && e[iE].d >= _query.r; ++iE) dsu.unionSet(e[iE].u, e[iE].v);
for (int j = i; j <= _.se; ++j) if (query[j].t == 1) edge_[ query[j].id ].d = query[j].r;
for (int j = i; j <= min(q, i + NGU - 1); ++j) if (query[j].t == 1 && edge_[ query[j].id ].d >= _query.r) {
gr[ dsu.findSet(edge[ query[j].id ].u) ].pb(dsu.findSet(edge[ query[j].id ].v) );
gr[ dsu.findSet(edge[ query[j].id ].v) ].pb(dsu.findSet(edge[ query[j].id ].u) );
}
dfs(dsu.findSet(_query.id) );
for (int __ : contain) {
ans[_.se] += dsu.szSet[__];
vis[__] = 0;
}
contain.clear();
for (int j = i; j <= min(q, i + NGU - 1); ++j) if (query[j].t == 1 && edge_[ query[j].id ].d >= _query.r) {
gr[ dsu.findSet(edge[ query[j].id ].u) ].clear();
gr[ dsu.findSet(edge[ query[j].id ].v) ].clear();
}
for (int j = i; j <= _.se; ++j) if (query[j].t == 1) edge_[ query[j].id ].d = edge[ query[j].id ].d;
}
for (int j = 1; j <= m; ++j) if (exist[j]) setEdge.erase( { edge[j], j } );
for (int j = i; j <= min(q, i + NGU - 1); ++j) if (query[j].t == 1) edge_[ query[j].id ].d = edge[ query[j].id ].d = query[j].r;
for (int j = 1; j <= m; ++j) if (exist[j]) setEdge.insert( { edge[j], j } );
}
for (int i = 1; i <= q; ++i) if (query[i].t == 2) printf("%d\n", ans[i]);
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
bridges.cpp: In function 'int main()':
bridges.cpp:50:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d %d", &n, &m);
~~~~~^~~~~~~~~~~~~~~~~
bridges.cpp:52:27: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
int u, v, d; scanf("%d %d %d", &u, &v, &d);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
bridges.cpp:56:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d", &q);
~~~~~^~~~~~~~~~
bridges.cpp:58:28: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
int t, id, r; scanf("%d %d %d", &t, &id, &r);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
# | 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... |