国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Codeforces Round #396 (Div. 2)D. Mahmoud and a Dictionary(帶權并查集)

2019-11-10 16:46:51
字體:
來源:轉載
供稿:網友

題目鏈接:點擊打開鏈接

思路:

帶權并查集水題。  帶權并查集可以知道在一個集合里的兩點間距離。那么這種同義反義關心恰好對應距離的奇偶。

附上一圖:

這就是合并的過程。

細節參見代碼:

#include <cstdio>#include <cstring>#include <algorithm>#include <iostream>#include <string>#include <vector>#include <stack>#include <ctime>#include <bitset>#include <cstdlib>#include <cmath>#include <set>#include <list>#include <deque>#include <map>#include <queue>#define Max(a,b) ((a)>(b)?(a):(b))#define Min(a,b) ((a)<(b)?(a):(b))using namespace std;typedef long long ll;typedef long double ld;const double eps = 1e-6;const double PI = acos(-1);const int mod = 1000000000 + 7;const int INF = 0x3f3f3f3f;// & 0x7FFFFFFFconst int seed = 131;const ll INF64 = ll(1e18);const int maxn = 1e5+10;int T,n,m,q,p[maxn],dist[maxn];map<string, int> mp;char s[33], s1[33];int _find(int x) {    if(p[x] == x) return x;    int oldfa = p[x];    p[x] = _find(p[x]);    dist[x] = (dist[x] + dist[oldfa])%2;    return p[x];}void init() {    for(int i = 1; i <= n; i++) {        p[i] = i;        dist[i] = 0;    }}int main() {    scanf("%d%d%d", &n, &m, &q);    for(int i = 1; i <= n; i++) {        scanf("%s", s);        mp[s] = i;    }    init();    for(int i = 1; i <= m; i++) {        int id; scanf("%d%s%s", &id, s, s1);        int id1 = mp[s], id2 = mp[s1];        int x = _find(id1), y = _find(id2);        if(x != y) {            PRintf("YES/n");            if(id == 1) p[x] = y, dist[x] = (dist[id2]-dist[id1]+2)%2;            else p[x] = y, dist[x] = (dist[id2]-dist[id1]+1+2)%2;        }        else {            int cur = (dist[id1]-dist[id2]+2)%2;            if(id == 1) {                if(cur & 1) printf("NO/n");                else printf("YES/n");            }            else {                if(cur & 1) printf("YES/n");                else printf("NO/n");            }        }    }    while(q--) {        scanf("%s%s", s, s1);        int id1 = mp[s], id2 = mp[s1];        int x = _find(id1), y = _find(id2);        if(x != y) printf("3/n");        else {            int cur = (dist[id1] - dist[id2] + 2)%2;            if(cur & 1) printf("2/n");            else printf("1/n");        }    }    return 0;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昭觉县| 句容市| 长泰县| 安平县| 无棣县| 阿巴嘎旗| 许昌县| 麦盖提县| 牟定县| 湖北省| 申扎县| 吐鲁番市| 南汇区| 盖州市| 长宁区| 石首市| 东光县| 临城县| 保山市| 清新县| 鲁山县| 城市| 佛山市| 沙河市| 辉南县| 梧州市| 马边| 多伦县| 开封县| 修文县| 张掖市| 隆林| 右玉县| 定南县| 长乐市| 茶陵县| 进贤县| 延长县| 青铜峡市| 贵港市| 洛浦县|