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;
const int mxN = 50005, mxM = 100005;
vector<tuple<int,int,int>> edges;
vector<pair<int,int>> queries[mxM];
int par[mxN], ccsz[mxN], ans[mxM];
int find(int x) { if(par[x]==x) return x; else return par[x] = find(par[x]); }
void merge(int a, int b) {a=find(a),b=find(b);if(a==b)return;par[a]=b; ccsz[b] += ccsz[a]; ccsz[a] = -1;}
signed main() {
	//freopen("bridge.in", "r", stdin);
	//freopen("bridge.out", "w", stdout);
	int n, m; cin >> n >> m;
	for(int i = 1; i <= m; i++) {
		int u, v, d; cin >> u >> v >> d;
		edges.push_back({d,u,v});
	}
	for(int i = 0; i < mxN; i++) par[i] = i, ccsz[i] = 1;
	sort(edges.begin(), edges.end());
	int q; cin >> q;
	for(int g = 0; g < q; g++) {
		int t; cin >> t;
		if(t==1) {
			exit(-1);
			int b, r; cin >> b >> r;
		} else {
			int s, w; cin >> s >> w;
			auto lb = lower_bound(edges.begin(), edges.end(), make_tuple(w, LLONG_MIN, LLONG_MIN));
			queries[lb - edges.begin()].push_back({s,g});
		}
	}
	for(int i = 0; i < mxN; i++) ans[i] = 1;
	for(int e = int(edges.size()) - 1; e >= 0; e--) {
		int u,v,d; tie(u,v,d) = edges[e];
		merge(u,v);
		for(int f = 0; f < queries[e].size(); f++) {
			int pos, oid; tie(pos, oid) = queries[e][f];
			ans[oid] = ccsz[find(pos)];
		}
	}
	for(int g = 0; g < q; g++) {
		cout << ans[g] << '\n';
	}
}
Compilation message (stderr)
bridges.cpp: In function 'int main()':
bridges.cpp:35:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   35 |   for(int f = 0; f < queries[e].size(); f++) {
      |                  ~~^~~~~~~~~~~~~~~~~~~| # | 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... |