제출 #978577

#제출 시각아이디문제언어결과실행 시간메모리
978577akacool445k다리 (APIO19_bridges)C++14
13 / 100
3098 ms19764 KiB
#include <bits/stdc++.h> using namespace std; #define ff first #define ss second // #define int long long const long long mod = 1e9 + 7; const long long shrek = (1 << 30); const int gay = 5e4 + 10; set<pair<pair<int, int>, int>> adj[gay]; bool vis[gay]; vector<int> cur; void dfs(int x, int w) { if(vis[x] == 1) return; vis[x] = 1; cur.push_back(x); for(auto y : adj[x]) { if(y.ff.ss < w) { continue; } dfs(y.ff.ff, w); } } signed main() { int n, m, q; cin >> n >> m; int u[m + 5], v[m + 5], w[m + 5]; for(int i = 1; i <= m; i++) { cin >> u[i] >> v[i] >> w[i]; adj[u[i]].insert({{v[i], w[i]}, i}); adj[v[i]].insert({{u[i], w[i]}, i}); } cin >> q; while(q--) { int c, st, f; cin >> c >> st >> f; if(c == 1) { adj[u[st]].erase({{v[st], w[st]}, st}); adj[v[st]].erase({{u[st], w[st]}, st}); w[st] = f; adj[u[st]].insert({{v[st], w[st]}, st}); adj[v[st]].insert({{u[st], w[st]}, st}); } else { cur.clear(); dfs(st, f); for(int x : cur) vis[x] = 0; cout << cur.size() << '\n'; } } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...