P1332 血色先鋒隊

2022-05-13 13:05:52 字數 1831 閱讀 5999

巫妖王的天災軍團終於捲土重來,血色十字軍組織了一支先鋒軍前往諾森德大陸對抗天災軍團,以及一切沾有亡靈氣息的生物。孤立於聯盟和部落的血色先鋒軍很快就遭到了天災軍團的重重包圍,現在他們將主力只好聚集了起來,以抵抗天災軍團的圍剿。可怕的是,他們之中有人感染上了亡靈瘟疫,如果不設法阻止瘟疫的擴散,很快就會遭到滅頂之災。大領主阿比迪斯已經開始調查瘟疫的源頭。原來是血色先鋒軍的內部出現了叛徒,這個叛徒已經投靠了天災軍團,想要將整個血色先鋒軍全部轉化為天災軍團!無需驚訝,你就是那個叛徒。在你的行蹤敗露之前,要盡快完成巫妖王交給你的任務。

軍團是乙個n行m列的矩陣,每個單元是乙個血色先鋒軍的成員。感染瘟疫的人,每過乙個小時,就會向四周擴散瘟疫,直到所有人全部感染上瘟疫。你已經掌握了感染源的位置,任務是算出血色先鋒軍的領主們感染瘟疫的時間,並且將它報告給巫妖王,以便對血色先鋒軍進行一輪有針對性的圍剿。

輸入格式:

第1行:四個整數n,m,a,b,表示軍團矩陣有n行m列。有a個感染源,b為血色敢死隊中領主的數量。

接下來a行:每行有兩個整數x,y,表示感染源在第x行第y列。

接下來b行:每行有兩個整數x,y,表示領主的位置在第x行第y列。

【資料規模】

1<=m,n<=500

1<=a,b<=m*n

輸出格式:

第1至b行:每行乙個整數,表示這個領主感染瘟疫的時間,輸出順序與輸入順序一致。如果某個人的位置在感染源,那麼他感染瘟疫的時間為0。

輸入樣例#1:

5 4 2 3

1 15 4

3 35 3

2 4

輸出樣例#1:

3

13

如下圖,標記出了所有人感染瘟疫的時間以及感染源和領主的位置。

這個題的資料有毒啊。。

怎麼搜都超時啊。。

看了一下題解,發現這個題解非常凝練

首先優化了vis陣列

然後優化了儲存領袖的陣列、、

1 #include2 #include3 #include4 #include5 #include6

using

namespace

std;

7const

int maxn=1001;8

void read(int &n)916

while(c>='

0'&&c<='9'

)17 x=x*10+c-48,c=getchar();

18 flag==1?n=-x:n=x;

1920}21

intn,m,gr,pep,x,y;

22int

out[maxn*100

];23

intmap[maxn][maxn];

24struct

node

25now,nxt;

28int

willx[maxn],willy[maxn];

29int xx[7]=;

30int yy[7]=;

31int jzx[maxn*100],jzy[maxn*100

];32 queueq;

33void

bfs()

3450}51

}52}53

intmain()

5466

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

6772

bfs();

73for(int i=1;i<=pep;i++)

7477

return0;

78 }

題解 P1332 血色先鋒隊

中心思想是進行乙個貪心 輸入乙個領主的位置,求出與所有感染源的曼哈頓距離,再取最小值,找到最近的乙個感染源,輸出感染源與這個領主的曼哈頓距離。ps 曼哈頓距離 在平面上,座標 x1,y1 的i點與座標 x2,y2 的j點的曼哈頓距離為 d i j x1 x2 y1 y2 include using ...

洛谷 P1332 血色先鋒隊

巫妖王的天災軍團終於捲土重來,血色十字軍組織了一支先鋒軍前往諾森德大陸對抗天災軍團,以及一切沾有亡靈氣息的生物。孤立於聯盟和部落的血色先鋒軍很快就遭到了天災軍團的重重包圍,現在他們將主力只好聚集了起來,以抵抗天災軍團的圍剿。可怕的是,他們之中有人感染上了亡靈瘟疫,如果不設法阻止瘟疫的擴散,很快就會遭...

洛谷 P1332 血色先鋒隊(BFS)

巫妖王的天災軍團終於捲土重來,血色十字軍組織了一支先鋒軍前往諾森德大陸對抗天災軍團,以及一切沾有亡靈氣息的生物。孤立於聯盟和部落的血色先鋒軍很快就遭到了天災軍團的重重包圍,現在他們將主力只好聚集了起來,以抵抗天災軍團的圍剿。可怕的是,他們之中有人感染上了亡靈瘟疫,如果不設法阻止瘟疫的擴散,很快就會遭...