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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

洛谷 P3356 火星探险问题

發布時間:2023/12/18 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 洛谷 P3356 火星探险问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題面

題意

給出一張地圖,上面有一些石塊或障礙,現在有一些運載車從左上角出發,要去右下角,只能向右或向下走,每個石塊只能收集一次,輸出收集到最多石塊的路徑.

做法

多個運載車,不難想到是網絡流,但難點在于每個石塊最多收集一次,而且要收集最多石塊.
可以用費用流來做,每個點拆成兩個入點向出點連一條流量為INF,費用為0的邊,如果該地有石塊,則再連一條流量為1,費用為-1的邊,最后跑費用流,再用dfs輸出路徑即可.

代碼

#include<iostream> #include<cstdio> #include<cstring> #include<queue> #define N 20010 #define INF 0x3f3f3f3f #define zh(i,j) ((i-1)*n+j) using namespace std;int n,m,k,ans,bb=1,first[N],s,t,last[N],B[N],d[N],mf,mm[40][40]; bool in[N]; struct Bn {int to,next,quan,cst; } bn[1001000]; queue<int>que;inline void add(int u,int v,int w,int z) {bb++;bn[bb].to=v;bn[bb].next=first[u];bn[bb].quan=w;bn[bb].cst=z;first[u]=bb; }inline void ad(int u,int v,int w,int z) { // cout<<u<<" "<<v<<" "<<w<<" "<<z<<endl;add(u,v,w,z);add(v,u,0,-z); }inline bool bfs() {int p,q,mn=INF;for(; !que.empty(); que.pop());memset(d,0x3f,sizeof(d));que.push(s);d[s]=0;for(; !que.empty();){q=que.front();que.pop();in[q]=0;for(p=first[q]; p!=-1; p=bn[p].next){if(d[bn[p].to]>d[q]+bn[p].cst&&bn[p].quan){d[bn[p].to]=d[q]+bn[p].cst;last[bn[p].to]=q;B[bn[p].to]=p;if(!in[bn[p].to]){in[bn[p].to]=1;que.push(bn[p].to);}}}}if(d[t]==INF) return 0;for(p=t; p!=s; p=last[p]){mn=min(mn,bn[B[p]].quan);}ans+=mn*d[t];mf+=mn;for(p=t; p!=s; p=last[p]){bn[B[p]].quan-=mn;bn[B[p]^1].quan+=mn;}return 1; }void df(int now,int u) {if(now==2*m*n) return;int p,q;for(p=first[now];p!=-1;p=bn[p].next){if(bn[p].quan!=INF&&bn[p].quan>100){bn[p].quan++;printf("%d %d\n",u,(now-1)%n<(bn[p].to-1)%n);df(bn[p].to+m*n,u);return;}} }int main() {memset(first,-1,sizeof(first));int i,j,p,q,o,z;cin>>p>>n>>m;ad(s,1,p,0);t=2*m*n;for(i=1;i<=m;i++){for(j=1;j<=n;j++){scanf("%d",&mm[i][j]);ad(zh(i,j),zh(i,j)+m*n,1,-(mm[i][j]==2));ad(zh(i,j),zh(i,j)+m*n,INF,0);}}for(i=1;i<=m;i++){for(j=1;j<=n;j++){if(i<m&&mm[i+1][j]!=1) ad(zh(i,j)+m*n,zh(i+1,j),INF,0);if(j<n&&mm[i][j+1]!=1) ad(zh(i,j)+m*n,zh(i,j+1),INF,0);}}for(; bfs();); // cout<<mf<<" "<<ans; // return 0;for(i=1;i<=p;i++){df(1+m*n,i);} }

總結

以上是生活随笔為你收集整理的洛谷 P3356 火星探险问题的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 91成年人视频 | 一区二区三区少妇 | 亚洲精品乱码久久久久久日本蜜臀 | 免费午夜激情 | 性高跟鞋xxxxhd国产电影 | 中文字幕永久免费 | 最好看的日本字幕mv视频大全 | 超级黄色录像 | 黑人与日本少妇高潮 | 九色综合网 | 美女扒开尿口让男人捅爽 | 欧美男女交配视频 | 星空无限mv国产剧入选 | 少妇性l交大片免费观看 | 国产国语老龄妇女a片 | 日韩区在线 | 五月天综合激情网 | 91在线精品播放 | 亚洲女人天堂成人av在线 | 亚洲欧洲日本一区二区三区 | 香蕉伊人 | 日本一区二区三区在线观看视频 | 狠狠狠狠狠狠干 | 亚洲高清免费观看 | 亚洲欧美国产一区二区 | 国产做受91 | 中文字幕手机在线视频 | 伊人亚洲综合 | 欧美精品成人 | 国产不卡视频在线 | 国产一区二区网站 | 欧美成人hd | 欧美一级网站 | 叶山小百合av一区二区 | 91最新入口 | av视屏 | 另类中文字幕 | 微拍福利一区二区 | 精品一区二区视频在线观看 | 国产成人精品123区免费视频 | 色综合久久久久综合体桃花网 | 日本伦理片在线播放 | 免费av黄色 | 黄色一级片在线 | 天天碰天天 | 国产高潮在线观看 | av一区在线观看 | 免费在线观看av片 | 色撸撸在线 | 校园伸入裙底揉捏1v1h | 91大奶| 性生交大片免费看 | 久久爱伊人 | 尹人成人 | 光明影院手机版在线观看免费 | 一区二区三区四区视频在线观看 | 好吊妞视频一区二区三区 | 国产特级淫片免费看 | 香蕉视频免费在线 | 精品久久久久久中文字幕人妻最新 | wwwxxx在线观看 | www.日本高清 | 亚洲啪啪网站 | 肉色欧美久久久久久久免费看 | 午夜精品三级久久久有码 | 国产又爽又猛又粗的视频a片 | 免费在线精品视频 | 久久久www成人免费精品 | 97久久超碰| 毛片最新网址 | 视频免费1区二区三区 | 最好看的中文字幕国语电影mv | 男男车车的车车网站w98免费 | 国产伦精品一区二区三区高清版 | 日本在线观看一区 | 我把护士日出水了视频90分钟 | 中文在线资源天堂 | 99国产精品99久久久久久 | 一级欧美一级日韩 | 国产一线在线观看 | 久久久久1 | 大伊人久久| 成人性生交大免费看 | 国产精品99久 | 国产美女自拍 | 欧美日韩精选 | 日韩三级网 | 四虎免费网址 | 韩国无码一区二区三区精品 | 欧美特级a | 亚洲av无码乱码国产精品久久 | 欧美一级视频免费 | 91看片免费版 | 国内精品视频 | 国产免费一区视频观看免费 | 日本猛少妇色xxxxx | 99国产精品久久久久久久成人 | 99爱精品视频 | 久久中文字幕一区 |