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

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

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

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

題目鏈接:點擊打開鏈接

思路:

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

附上一圖:

這就是合并的過程。

細節參見代碼:

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沐川县| 富蕴县| 南和县| 綦江县| 南京市| 宁城县| 南皮县| 屯留县| 元江| 儋州市| 平阴县| 麻阳| 科技| 大同市| 连云港市| 清河县| 巴林右旗| 曲麻莱县| 阿勒泰市| 阿图什市| 酉阳| 秭归县| 新昌县| 炉霍县| 慈利县| 德惠市| 留坝县| 新沂市| 南昌县| 永靖县| 沈阳市| 栾川县| 彭水| 中宁县| 丁青县| 太白县| 龙门县| 乌兰察布市| 康马县| 乐亭县| 英德市|