洛谷P4171 JSOI2010 滿漢全席

2022-05-29 05:18:06 字數 2644 閱讀 3575

滿漢全席是中國最豐盛的宴客菜餚,有許多種不同的材料透過滿族或是漢族的料理方式,呈現在數量繁多的菜色之中。由於菜色眾多而繁雜,只有極少數博學多聞技藝高超的廚師能夠做出滿漢全席,而能夠烹飪出經過專家認證的滿漢全席,也是中國廚師最大的榮譽之一。世界滿漢全席協會是由能夠料理滿漢全席的專家廚師們所組成,而他們之間還細分為許多不同等級的廚師。

為了招收新進的廚師進入世界滿漢全席協會,將於近日舉辦滿漢全席大賽,協會派遣許多會員當作評審員,為的就是要在參賽的廚師之中,找到滿漢料理界的明日之星。

大會的規則如下:每位參賽的選手可以得到n 種材料,選手可以自由選擇用滿式或是漢式料理將材料當成菜餚。

大會的評審制度是:共有m 位評審員分別把關。每一位評審員對於滿漢全席有各自獨特的見解,但基本見解是,要有兩樣菜色作為滿漢全席的標誌。如某評審認為,如果沒有漢式東坡肉跟滿式的涮羊肉鍋,就不能算是滿漢全席。但避免過於有主見的審核,大會規定乙個評審員除非是在認為必備的兩樣菜色都沒有做出來的狀況下,才能淘汰一位選手,否則不能淘汰一位參賽者。

換句話說,只要參賽者能在這兩種材料的做法中,其中乙個符合評審的喜好即可通過該評審的審查。如材料有豬肉,羊肉和牛肉時,有四位評審員的喜好如下表:

評審一 評審二 評審三 評審四 

滿式牛肉 滿式豬肉 漢式牛肉 漢式牛肉

漢式豬肉 滿式羊肉 漢式豬肉 滿式羊肉

如參賽者甲做出滿式豬肉,滿式羊肉和滿式牛肉料理,他將無法滿足評審三的要求,無法通過評審。而參賽者乙做出漢式豬肉,滿式羊肉和滿式牛肉料理,就可以滿足所有評審的要求。

但大會後來發現,在這樣的制度下如果材料選擇跟派出的評審員沒有特別安排好的話,所有的參賽者最多只能通過部分評審員的審查而不是全部,所以可能會發生沒有人通過考核的情形。

如有四個評審員喜好如下表時,則不論參賽者採取什麼樣的做法,都不可能通過所有評審的考核:

評審一 評審二 評審三 評審四 

滿式羊肉 滿式豬肉 漢式羊肉 漢式羊肉

漢式豬肉 滿式羊肉 漢式豬肉 滿式豬肉

所以大會希望有人能寫乙個程式來判斷,所選出的m 位評審,會不會發生 沒有人能通過考核的窘境,以便協會組織合適的評審團。

輸入格式:

第一行包含乙個數字 k,代表測試檔案包含了k 組資料。

每一組測試資料的第一行包含兩個數字n 跟m(n≤100,m≤1000),代表有n 種材料,m 位評審員。

為方便起見,材料捨棄中文名稱而給予編號,編號分別從1 到n。

接下來的m 行,每行都代表對應的評審員所擁有的兩個喜好,每個喜好由乙個英文本母跟乙個數字代表,如m1 代表這個評審喜歡第1 個材料透過滿式料理做出來的菜,而h2 代表這個評審員喜歡第2 個材料透過漢式料理做出來的菜。

每個測試檔案不會有超過50 組測試資料

輸出格式:

每筆測試資料輸出一行,如果不會發生沒有人能通過考核的窘境,輸出good;否則輸出bad(大寫字母)。

輸入樣例#1: 複製

2

3 4m3 h1

m1 m2

h1 h3

h3 m2

2 4h1 m2

m2 m1

h1 h2

m1 h2

輸出樣例#1: 複製

good

bad題解:2——sat, 一種材料拆兩個點,1~n做漢, n+1^2n做滿,如果不滿足乙個評委,就必須滿足另乙個評委

我開始用char讀數,後來發現菜品》10,一直wa;

#include using

namespace

std;

const

int m = 505, inf = 100000008

;int

dfn[m], low[m], h[m], tot, idx, dep, ins[m], sccnt, place[m];

intn;

stack

s;struct edgeg[500000

];void add(int u, int v)

void tarjan(int

u)

else

if(ins[v])

low[u] =min(dfn[v], low[u]);

}if(low[u] ==dfn[u])

}}void add_edge(int c1, int t1, int c2, int

t2)void

init()

intmain()

for(int i = 1; i <= 2*n; i++)

if(!dfn[i])

tarjan(i);

for(int i = 1; i <= n; i++)

if(place[i] == place[i+n])

if(fg)puts("

bad"

);

else puts("

good");

}return0;

}/*22 4

h1 m2

m2 m1

h1 h2

m1 h2

3 4m3 h1

m1 m2

h1 h3

h3 m2

*/

view code

洛谷P4171 JSOI2010 滿漢全席

題目大意 有 n 個點,每個點可以選或不選,有 m 組約束,形如 a,u,b,v 表示 u a,v b 中至少要滿足乙個條件,問是否存在一組解,多組詢問 題解 2 sat 感覺是板子題呀,最後判斷一下每乙個點選與不選是否在同乙個強連通分量內即可 卡點 無 c code include include...

P4171 JSOI2010 滿漢全席

傳送門 顯然的 2 sat 問題,甚至不用輸出方案 每種菜不是漢式就是滿式,分成兩個節點 i,n i 分別表示滿式和漢式 對於限制 m i,m j 如果 i 為漢式則 j 一定要為滿式,如果 j 為漢式 i 一定為滿式 所以連邊 n i,j n j,i 其他情況同理,最後 tarjan 縮一下聯通塊...

題解 P4171 JSOI2010 滿漢全席

這道題目是一道很明顯的2 sat問題,但要注意變數是每個材料,值是蒙式或漢式,而不是 蒙式xx為1或漢式xx為1 目測沒有必要用tarjan,畢竟理論時間複雜度一樣,常數需要時卡一卡就行了。include include include includeusing namespace std cons...