火星探險問題

2021-08-14 07:55:10 字數 1308 閱讀 1549

乙個點同一時間只有一輛車,這個條件並沒有用

因為你可以一輛車一輛車走

於是這個題就和深海機械人問題一樣了,只需要把乙個位置拆成兩個點就好了

輸出方案就dfs一下,記乙個陣列,每次搜過它就++,如果等於這條邊流過的流量就不能走

然後就沒了記得檢查陣列大小,不然wa兩遍還不知道陣列開小了

# include 

# define rg register

# define il inline

# define fill(a, b) memset(a, b, sizeof(a))

using namespace std;

typedef

long

long ll;

const

int _(5010), __(1e6 + 10), inf(2e9);

il ll read()

int n, p, q, id[50][50], tmp[__], mp[50][50], num, ans[__], len;

int cnt, fst[_], w[__], to[__], nxt[__], dis[_], vis[_], s, t, cost[__], pe[_], pv[_], max_flow;

queue q;

il void add(rg int u, rg int v, rg int f, rg int co)

il bool bfs()

vis[u] = 0;

}if(dis[t] >= dis[t + 1]) return

0; rg int ret = inf;

for(rg int u = t; u != s; u = pv[u]) ret = min(ret, w[pe[u]]);

for(rg int u = t; u != s; u = pv[u]) w[pe[u]] -= ret, w[pe[u] ^ 1] += ret;

max_flow += ret;

return1;}

il void dfs(rg int x, rg int y)

if(to[e] == d1)

}}int main(rg int argc, rg char *argv)

for(rg int i = 1; i <= p; ++i)

for(rg int j = 1; j <= q; ++j)

while(bfs());

for(rg int i = 1; i <= max_flow; ++i)

return

0;}

火星探險問題

7月倒數第二天補flag 拆點,像深海機械人問題一樣。最後求路線的時候dfs一下,根據流量判定走了幾個機械人,不能超過流量即可。include include include include using namespace std const int inf 0x3f3f3f3f,n 5000005...

火星探險 Mars

暫無鏈結 題目描述 在2051年,若干火星探險隊探索了這顆紅色行星的不同區域並且製作了這些區域的地圖。現在,baltic空間機構有乙個雄心勃勃的計畫,他們想製作一張整個行星的地圖。為了考慮必要的工作,他們需要知道地圖上已經存在的全部區域的大小。你的任務是寫乙個計算這個區域大小的程式。具體任務要求為 ...

洛谷 P3356 火星探險問題

給出一張地圖,上面有一些石塊或障礙,現在有一些運載車從左上角出發,要去右下角,只能向右或向下走,每個石塊只能收集一次,輸出收集到最多石塊的路徑.多個運載車,不難想到是網路流,但難點在於每個石塊最多收集一次,而且要收集最多石塊.可以用費用流來做,每個點拆成兩個入點向出點連一條流量為inf,費用為0的邊...