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

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

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

2019-11-10 18:39:31
字體:
來源:轉載
供稿:網友

題目鏈接:點擊打開鏈接

思路:

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

附上一圖:

這就是合并的過程。

細節參見代碼:

#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;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宿松县| 大埔县| 渑池县| 新和县| 汾阳市| 宜良县| 邵东县| 额敏县| 恩施市| 齐河县| 苏尼特右旗| 大荔县| 大理市| 晋中市| 焦作市| 台北市| 塘沽区| 陈巴尔虎旗| 精河县| 左云县| 莱西市| 黑水县| 瑞昌市| 紫云| 彩票| 广州市| 东平县| 滁州市| 阳曲县| 安国市| 西平县| 西吉县| 江源县| 丰宁| 麦盖提县| 肇庆市| 宜昌市| 永平县| 缙云县| 长丰县| 梅河口市|