帶權並查集 食物鏈

2022-07-16 13:18:12 字數 864 閱讀 5078

給你n組數,每組數由三個數構成,如果第乙個數是1,那麼就說明後面兩個數代表的物體是同類,如果第乙個數是2,那麼就代表第二個數吃第三個數,現在問你說假話的總數

這個題作為帶權並查集中的「拓展域」的模板題只能說過於經典,比上一道題簡單,我們可以很簡單的得到這道題的邏輯關係

我們需要將乙個節點拆成三份,分別表示同類域,捕食域,天敵域,那麼就可以得到以下邏輯關係

如何判斷是 x與y是同類 矛盾

如何判斷是 x吃y 矛盾

通過以上資訊,我們就能夠得到**如下

//#define fre yes

#include int n, k;

const int n = 50005;

namespace union

}int find(int x)

inline void unite(int x, int y)

inline bool same(int x, int y)

}int main()

if(d == 1)

union::unite(x, y);

union::unite(x + n, y + n);

union::unite(x + 2 * n, y + 2 * n);

}else if(d == 2)

union::unite(x, y + n);

union::unite(x + n, y + 2 * n);

union::unite(x + 2 * n, y);

}} printf("%d\n", ans);

return 0;

}

食物鏈 帶權並查集

食物鏈 d x 維護的是跟根節點的距離 如果x,y在同乙個集合中,然後通過兩個根節點的距離就可以知道兩個之間的關係 d x 可以為負數,如果為負數的話,是反向轉食物鏈 例如 y距離根節點為 1 x距離根節點為 5 則 1 5 1mod3 0 所以y吃x 畫圖的話需要反向轉圈 如果 x y 為同類 則...

並查集 食物鏈(帶權並查集)

題目鏈結 題意 動物王國中有三類動物a,b,c,這三類動物的食物鏈構成了有趣的環形。a b吃c,c吃a。現有n個動物,以1 n編號。每個動物都是a,b,c中的一種,但是我們並不知道它到底是哪一種。有人用兩種說法對這n個動物所構成的食物鏈關係進行描述 第一種說法是 1 x y 表示x和y是同類。第二種...

食物鏈 帶權並查集 1

動物王國中有三類動物a,b,c,這三類動物的食物鏈構成了有趣的環形。a吃b,b吃c,c吃a。現有n個動物,以1 n編號。每個動物都是a,b,c中的一種,但是我們並不知道它到底是哪一種。有人用兩種說法對這n個動物所構成的食物鏈關係進行描述 第一種說法是 1 x y 表示x和y是同類。第二種說法是 2 ...