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

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

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

2019-11-09 21:08:42
字體:
來源:轉載
供稿:網友

題目鏈接:點擊打開鏈接

思路:

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

附上一圖:

這就是合并的過程。

細節參見代碼:

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昆山市| 徐州市| 汝州市| 读书| 恭城| 晴隆县| 巴林左旗| 安阳市| 互助| 霍山县| 登封市| 沈丘县| 盘山县| 临洮县| 皮山县| 盘锦市| 许昌县| 沭阳县| 广东省| 新兴县| 邵武市| 镇江市| 尉犁县| 廉江市| 柏乡县| 许昌县| 定州市| 淮安市| 广州市| 永顺县| 隆德县| 阿巴嘎旗| 清水河县| 阜宁县| 高清| 屏东市| 宾川县| 潼南县| 凤台县| 秦安县| 台州市|