日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

1574: [Usaco2009 Jan]地震损坏Damage

發布時間:2023/12/4 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 1574: [Usaco2009 Jan]地震损坏Damage 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1574: [Usaco2009 Jan]地震損壞Damage

Time Limit:?10 Sec??Memory Limit:?64 MB
Submit:?425??Solved:?232
[Submit][Status][Discuss]

Description

農夫John的農場遭受了一場地震.有一些牛棚遭到了損壞,但幸運地,所有牛棚間的路經都還能使用. FJ的農場有P(1 <= P <= 30,000)個牛棚,編號1..P. C(1 <= C <= 100,000)條雙向路經聯接這些牛棚,編號為1..C. 路經i連接牛棚a_i和b_i (1 <= a_i<= P;1 <= b_i <= P).路經可能連接a_i到它自己,兩個牛棚之間可能有多條路經.農莊在編號為1的牛棚. N (1 <= N <= P)頭在不同牛棚的牛通過手機短信report_j(2 <= report_j <= P)告訴FJ它們的牛棚(report_j)沒有損壞,但是它們無法通過路經和沒有損壞的牛棚回到到農場. 當FJ接到所有短信之后,找出最小的不可能回到農莊的牛棚數目.這個數目包括損壞的牛棚. 注意:前50次提交將提供在一些測試數據上的運行結果.

Input

* 第1行: 三個空格分開的數: P, C, 和 N

* 第2..C+1行: 每行兩個空格分開的數: a_i 和 b_i * 第C+2..C+N+1行: 每行一個數: report_j

Output

* 第1行: 一個數,最少不能回到農莊的牛的數目(包括損壞的牛棚).

Sample Input

4 3 1
1 2
2 3
3 4
3


Sample Output

3

HINT

?

牛棚2遭到損壞,導致牛棚2, 3, 4里面的牛無法回到農莊.

?

Source

Gold

?

題解:一開始看到損壞什么的就想到割,然后就忍不住往最大流最小割上面想,事實證明我想多了。。。TT

一道搜索題,對于被割斷的點最少的情況下,一定是損壞的牛棚剛剛好可以把那些發了短信的點包圍導致其無法連通至1,然后根據這樣子的情況來求出一個最優的切割情況,然后直接DFS出最優切割情況下仍然連通的點數,然后用N減一下完事。。

1 type 2 point=^node; 3 node=record 4 g:longint; 5 next:point; 6 end; 7 var 8 i,j,k,l,m,n,t,ans:longint; 9 a:array[0..100000] of point; 10 b,c,d:array[0..100000] of longint; 11 p:point; 12 procedure add(x,y:longint);inline; 13 var p:point; 14 begin 15 new(p);p^.g:=y;p^.next:=a[x];a[x]:=p; 16 end; 17 procedure dfs(x:longint);inline; 18 var p:point; 19 begin 20 if b[x]<>0 then exit; 21 inc(ans);b[x]:=1; 22 p:=a[x]; 23 while p<>nil do 24 begin 25 if b[p^.g]=0 then dfs(p^.g); 26 p:=p^.next; 27 end; 28 end; 29 begin 30 readln(n,m,t); 31 for i:=1 to n do a[i]:=nil; 32 for i:=1 to m do 33 begin 34 readln(j,k); 35 add(j,k);add(k,j); 36 end; 37 fillchar(b,sizeof(b),0); 38 for i:=1 to t do 39 begin 40 readln(j); 41 b[j]:=1; 42 p:=a[j]; 43 while p<>nil do 44 begin 45 if b[p^.g]=0 then b[p^.g]:=-1; 46 p:=p^.next; 47 end; 48 end; 49 for i:=1 to n do if b[i]=1 then b[i]:=-1; 50 ans:=0; 51 dfs(1); 52 writeln(n-ans); 53 end.

?

轉載于:https://www.cnblogs.com/HansBug/p/4392069.html

總結

以上是生活随笔為你收集整理的1574: [Usaco2009 Jan]地震损坏Damage的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。