SDUT 食物鏈(帶權並查集)

2021-09-11 01:22:40 字數 2404 閱讀 2826

動物王國中有三類動物a,b,c,這三類動物的食物鏈構成了有趣的環形。a**, b吃c,c吃a。

現有n個動物,以1-n編號。每個動物都是a,b,c中的一種,但是我們並不知道它到底是哪一種。

有人用兩種說法對這n個動物所構成的食物鏈關係進行描述:

第一種說法是"1 x y",表示x和y是同類。

第二種說法是"2 x y",表示x吃y。

此人對n個動物,用上述兩種說法,一句接一句地說出k句話,這k句話有的是真的,有的是假的。當一句話滿足下列三條之一時,這句話就是假話,否則就是真話。

1) 當前的話與前面的某些真的話衝突,就是假話;

2) 當前的話中x或y比n大,就是假話;

3) 當前的話表示x吃x,就是假話。

你的任務是根據給定的n(1 <= n <= 50,000)和k句話(0 <= k <= 100,000),輸出假話的總數。

輸入

第一行是兩個整數n和k,以乙個空格分隔。

以下k行每行是三個正整數 d,x,y,兩數之間用乙個空格隔開,其中d表示說法的種類。

若d=1,則表示x和y是同類。

若d=2,則表示x吃y。

輸出

只有乙個整數,表示假話的數目。

輸入樣例

100 7

1 101 1

2 1 2

2 2 3

2 3 3

1 1 3

2 3 1

1 5 5

輸出樣例

3這道題是學長抓的並查集專題裡面的題 所以我就用了並查集的方法 當然此題並不侷限於並查集的方法

這個題剛開始看完題目大意 就是想的非常硬行的判斷後二個條件 然後第乙個條件之間判斷是否屬於乙個集合就好 但是… **沒寫出來 最後還是借鑑了dalao的部落格 鑽研了一波 服了人家的邏輯思維 orz

不扯了 正篇來了

第一步:

定義乙個rel[i]表示i和父親的關係

rel[i] = x1-------i與父親同級

rel[i] = x2-------i被父親吃

rel[i] = x3-------i吃父親

列舉假設三種狀態是子->父,父->爺,能推出子->爺的關係

列舉:子吃父,父被爺吃,則子爺同類-----------x3+x2=x1;

子吃父,父吃爺,則子被爺吃-------------2x3=x2;

子被父吃,父被爺吃,則子吃爺-----------2x2=x3;

上面第2,3個式子顯然是矛盾的,所以運用取模的思想,式子兩邊取模(x1,x2,x3要從0,1,2裡選,因為再大的數模3後也是這三個數)

rel[i]=0---------i與父親同級

rel[i]=1---------i被父親吃

rel[i]=2---------i吃父親

公式:rel[x](子到爺的關係) = (rel[x](子到父的關係)+rel[x](父到爺的關係))%3;

初始化的時候rel[i] = 0表示自己和自己是同類對後面並沒有影響

第二步:路徑壓縮

在路徑壓縮的時候就可以更新rel[3]來表示3到根節點1的關係(套用上面的公式)

第三步:

第二三個條件之間判斷然後變數ans計數然後continue

1)如果說兩個節點的根相同 那麼說明x,y已經被賦予了之間的關係 我們只需要判斷他們之間的關係是否正確就好

2)如果兩個節點的根節點不同 說明當前情況下我們並不知道x,y的關係 t1 = find(x),t2 = find(y) 關鍵就是怎麼求rel[t2]

rel[t2] = (rel[x] + flag - 1 + 3 - rel[y])%3;

這個公式我還不是特別的清楚 先碼起來

#include#include#includeint f[50050], rel[50050];

int find(int x)

int merge(int x, int y, int flag)

else return 1;

}f[t2] = t1;

rel[t2] = (rel[x] + flag + 3 - rel[y])%3;

return 1;

}int main()

while(k--)

if(flag==2&&x==y)

if(merge(x, y, flag-1)==0)

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

return 0;

}

食物鏈 帶權並查集

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

帶權並查集 食物鏈

給你n組數,每組數由三個數構成,如果第乙個數是1,那麼就說明後面兩個數代表的物體是同類,如果第乙個數是2,那麼就代表第二個數吃第三個數,現在問你說假話的總數 這個題作為帶權並查集中的 拓展域 的模板題只能說過於經典,比上一道題簡單,我們可以很簡單的得到這道題的邏輯關係 我們需要將乙個節點拆成三份,分...

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

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