###### Codeforces Round #286 (Div. 1) D. Mr. Kitayuta's Colorful Graph （并查集 STL）

AAA：姿势不对 会超时，正确的姿势是unordered_map,以及暴力遍历的时候要循环小的


#include<bits/stdc++.h>
using namespace std;
#define LL long long
#define pb push_back
#define X first
#define Y second
#define cl(a,b) memset(a,b,sizeof(a))
typedef pair<int,int> P;
const int maxn=100005;
const LL inf=1<<27;
const LL mod=1e9+7;
unordered_map<int,int> f[maxn],ans[maxn];

int Getf(int x,int c){
return x==f[x][c]?x:f[x][c]=Getf(f[x][c],c);
}
void Union(int c,int x,int y){
if(f[x].count(c)==0)f[x][c]=x;
if(f[y].count(c)==0)f[y][c]=y;
x=Getf(f[x][c],c);
y=Getf(f[y][c],c);
if(x==y)return ;
if(x>y)swap(x,y);
f[x][c]=y;
}
int main(){

int n,m,q;
scanf("%d%d",&n,&m);
for(int i=0;i<m;i++){
int u,v,c;
scanf("%d%d%d",&u,&v,&c);
if(u>v)swap(u,v);
Union(c,u,v);
}
scanf("%d",&q);
while(q--){
int x,y;scanf("%d%d",&x,&y);
if(f[x].size()>f[y].size())swap(x,y);///优化很重要
int Ans=0;
if(ans[x].count(y)){printf("%d\n",ans[x][y]);continue;}
for(auto k:f[x]){
if(f[y].count(k.X)==0)continue;
if(Getf(f[x][k.X],k.X)==Getf(f[y][k.X],k.X))Ans++;
}

ans[x][y]=Ans;
printf("%d\n",Ans);
}
return 0;
}


#### Codeforces 505B - Mr. Kitayuta's Colorful Graph (DFS)

2015-01-19 09:57:59

#### Codeforces 506D：Mr. Kitayuta's Colorful Graph 并查集

2016-02-01 21:34:48

#### CF 505B(Mr. Kitayuta's Colorful Graph-并查集)

2015-01-19 15:11:57

#### Codeforces Round #286 div.1 D 506D D. Mr. Kitayuta's Colorful Graph【并查集】

2015-01-30 01:40:44

#### Codeforces Round #382 (Div. 2)D. Taxes（数论知识)

2016-11-28 11:41:58

#### Codeforces Round #382 (Div. 2) D. Taxes（分拆素数和）

2016-11-28 12:13:11

#### Educational Codeforces Round 36 (Rated for Div. 2) 题解

2018-01-13 23:16:24

#### Codeforces Round #446 (Div. 2) D. Gluttony

2017-11-18 21:07:25

#### Codeforces Round #382 (Div. 2) -- D. Taxes （数学 -- 哥德巴赫猜想， 唯一分解定理）

2016-11-29 00:19:36

#### CF-Codeforces Round #483 (Div. 2) A~D

2018-05-16 00:48:25

## 不良信息举报

Codeforces Round #286 (Div. 1) D. Mr. Kitayuta's Colorful Graph （并查集 STL）