Submission #933994

#TimeUsernameProblemLanguageResultExecution timeMemory
933994leo_2727Bridges (APIO19_bridges)C++17
0 / 100
3026 ms12632 KiB
//13 points #include <algorithm> #include <fstream> #include <vector> #include <queue> #include <stack> #include <iostream> #include <cmath> #include <queue> #include <set> #include <cstring> #include <map> #include <unordered_map> #define F first #define S second #define PB push_back using namespace std; typedef long long ll; typedef pair<int, int> ii; typedef vector<int> vi; typedef vector<vi> vvi; typedef vector<ii> vii; typedef vector<pair<int, ii>> viii; typedef vector<vii> vvii; typedef vector<ll> vll; typedef vector<vll> vvll; int n, m; map<int, pair<ii, int>> bridges; vvii al; bool vis[50005]; void dfs(int node, int w){ if(vis[node]) return; vis[node]=true; for(auto ch:al[node]) if(ch.S>=w) dfs(ch.F, w); } int main(int argc, const char * argv[]) { ios_base::sync_with_stdio(false); cin.tie(NULL); cin>>n>>m; al.resize(n+1, vii ()); for(int i=1;i<=m;i++){ int x, y, w; cin>>x>>y>>w; al[x].PB({y, w}); al[y].PB({x, w}); bridges[i]={{x, y}, w}; } int q; cin>>q; while(q--){ int type, x, y; cin>>type>>x>>y; if(type==1){ int a=bridges[x].F.F, b=bridges[x].F.S, w=bridges[x].S; bridges[x]={{a, b}, w}; for(int i=0;i<(int)al[a].size();i++){ if(al[a][i].F==b && al[a][i].S==w){ al[a][i]={b, y}; break; } } for(int i=0;i<(int)al[b].size();i++){ if(al[b][i].F==a && al[b][i].S==w){ al[b][i]={a, y}; break; } } } else{ memset(vis, false, n+1); dfs(x, y); int ans=0; for(int i=1;i<=n;i++) if(vis[i]) ans++; cout<<ans<<"\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...