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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

SGU 185 Two shortest

發布時間:2024/8/23 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SGU 185 Two shortest 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

SGU_185

? ? 這個題目被內存卡的嚴重頭暈……

? ? 其實思路還是滿直觀的,由于要兩條路不相交,只要用網絡流就行,再加上要兩條最短路,那么就最小費用最大流,最后看兩條路的費用和是不是最短路的兩倍即可。但如果裸著這樣寫,由于無向邊相當于兩條有向邊,不好意思,內存爆了……開小點吧,不好意思,RE了……

? ? 暈……那還是換網絡流寫吧,這樣少個記錄費用的數組,可以先用dij從1開始搞遍最短路,再從N開始搞遍最短路,再遍歷一遍所有邊就知道哪條邊是最短路上的邊了,而且還知道了這條邊的方向,那么根據這些最短路上的邊組成的圖做最大流就可以了,最后看總流量是不是為2。

? ? 當然敲到這里就發現了省內存的方法,只要先找到哪些邊是最短路上的邊,那么這些邊就會定向了,于是內存就可以剩一半了,這時候再用費用流就不會爆內存了,不過你寫著寫著就會發現,好像這個費用流要邊權沒啥用哦,因為費用是沒關系的,反正都是最短路上的邊。那就把費用設成0吧,算了,干脆不要費用這個數組了,于是最后寫著寫著,咦,又寫回網絡流了,不要費用的最小費用最大流算法不就是EK嘛=_=

? ? 不過值得一提的是,在輸出最終路徑時不能這樣:先做一遍最大流,把增廣路存下來,再做一遍最大流,再把增廣路存下來,然后輸出兩條增廣路。因為第二次的增廣路有可能走逆向邊的,也就是說相當于反悔之前的某個走法,這樣顯然就不對了,因為相當于這條邊沒有走但兩次增廣路中又都包含了這條邊。不過可以最后根據殘量網絡直接沿殘量為0的正向邊走到終點,順便把殘量置1,這樣走兩遍就輸出了那兩條路徑了。

#include<stdio.h> #include<string.h> #include<algorithm> #define MAXD 410 #define MAXM 160010 #define INF 0x3f3f3f3f int N, M, g[MAXD][MAXD], first[MAXD], e, next[MAXM], v[MAXM], flow[MAXM]; int S, T, q[MAXD], d[MAXD], work[MAXD], diss[MAXD], dist[MAXD], pre[MAXD]; void init() {int i, x, y, z;memset(g, 0x3f, sizeof(g));for(i = 0; i < M; i ++){scanf("%d%d%d", &x, &y, &z);g[x][y] = g[y][x] = z; } } void dij(int S, int T, int *dis) {int i, j, k, min;memset(dis, 0x3f, sizeof(diss[0]) * (N + 1));memset(d, 0, sizeof(d[0]) * (N + 1));dis[S] = 0;for(;;){min = INF;for(i = 1; i <= N; i ++) if(!d[i] && dis[i] < min) min = dis[k = i];if(min == INF) break;d[k] = 1;for(i = 1; i <= N; i ++) dis[i] = std::min(dis[i], dis[k] + g[k][i]);} } int bfs() {int i, j, rear = 0;memset(d, -1, sizeof(d[0]) * (N + 1));d[S] = 0, q[rear ++] = S;for(i = 0; i < rear; i ++)for(j = first[q[i]]; j != -1; j = next[j])if(flow[j] && d[v[j]] == -1){d[v[j]] = d[q[i]] + 1, q[rear ++] = v[j];if(v[j] == T) return 1; }return 0; } int dfs(int cur, int a) {if(cur == T) return a;for(int &i = work[cur]; i != -1; i = next[i])if(flow[i] && d[v[i]] == d[cur] + 1)if(int t = dfs(v[i], std::min(a, flow[i]))){flow[i] -= t, flow[i ^ 1] += t;return t; } return 0; } int dinic() {int ans = 0, t;while(bfs()){memcpy(work, first, sizeof(first[0]) * (N + 1));while(t = dfs(S, INF))ans += t;}return ans; } void add(int x, int y, int z) {v[e] = y, flow[e] = z;next[e] = first[x], first[x] = e ++; } void print() {int i, cur = 1;for(;;){if(cur == T){printf("%d\n", cur);return ; }printf("%d ", cur);for(i = first[cur]; i != -1; i = next[i])if((i & 1) == 0 && flow[i] == 0){flow[i] = 1, cur = v[i];break; }} } void solve() {int i, j;dij(1, N, diss), dij(N, 1, dist);if(diss[N] == INF){printf("No solution\n");return ; }memset(first, -1, sizeof(first[0]) * (N + 1)), e = 0;for(i = 1; i <= N; i ++)for(j = 1; j <= N; j ++)if(i != j && diss[i] + g[i][j] + dist[j] == diss[N])add(i, j, 1), add(j, i, 0);S = 0, T = N;add(S, 1, 2), add(1, S, 0);if(dinic() != 2)printf("No solution\n");elseprint(), print(); } int main() {while(scanf("%d%d", &N, &M) == 2){init();solve(); }return 0; }

轉載于:https://www.cnblogs.com/staginner/archive/2012/08/20/2647342.html

總結

以上是生活随笔為你收集整理的SGU 185 Two shortest的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 一区二区三区精 | 动漫美女放屁 | 高清视频在线免费观看 | 国产日韩一区二区三免费高清 | 亚洲欧美另类视频 | 三年中文免费观看大全动漫 | 国产一级伦理片 | 亚洲黄色影视 | 欧美日一区二区三区 | 国产欧美精品一区二区色综合朱莉 | 精品视频免费在线 | 手机看片国产1024 | 九九久久国产精品 | 怡春院一区二区 | 成年人网站免费看 | 精品视频一区二区三区在线观看 | 一级特黄a | 九九久久国产精品 | 亚洲片在线观看 | 人人叉人人 | 嫩草社区 | 日韩精品在线免费观看 | 日韩成人高清视频在线观看 | 亚洲精品在线不卡 | 91丨九色丨国产 | 6080av| 青青草免费看 | 欧美久久久久久久久久 | av在线.com | 久久国产精品无码一区二区 | 男女日日 | 欧美日韩成人网 | 婷综合| yw在线观看| 日本wwwxx | 美女av在线免费观看 | 91高清视频免费观看 | 伊人春色在线视频 | 亚洲av永久无码精品三区在线 | 国产精品无码久久久久高潮 | 少妇脱了内裤让我添 | 中文字幕一区二区三区乱码人妻 | 日本一区二区三区中文字幕 | 熟女少妇a性色生活片毛片 亚洲伊人成人网 | 成人免费国产 | 九九视频在线免费观看 | 日韩av在线一区 | 一级特黄欧美 | 亚洲一区二区精品在线观看 | 日韩人体视频 | 91美女网| 欧美天天视频 | 国产女厕一区二区三区在线视 | 亚洲天堂自拍 | 日本不卡在线视频 | 超碰1000| 在线观看黄色片网站 | 久久精品二区 | 亚洲精品久久久久久久久 | 一区二区三区四区影院 | 精品国产18久久久久久 | 美女黄色真播 | 精品伦理一区二区 | 美女隐私无遮挡 | 777在线视频| 亚洲a黄| 精品一区精品二区 | 在线免费观看黄色网址 | 麻豆精品 | 国产视频在线观看视频 | 亚洲精品资源在线 | 日本精品一二三 | 红杏出墙记 | 人av在线 | 国语对白av | 成人毛片视频网站 | 夜夜春av| 日韩成人在线一区 | 成年人福利网站 | 在线色导航 | 国产精品亚洲一区二区三区在线观看 | www久久久久久 | 高潮白浆女日韩av免费看 | 久久久久亚洲av成人无码电影 | 黑人番号 | 亚洲666 | 91在线视频精品 | 蜜桃91精品入口 | 国产精品成人免费一区二区视频 | 女色婷婷| jizz色| 久久久久久艹 | 国产人妻黑人一区二区三区 | 国产精品免费精品一区 | 亚洲欧美日韩精品永久在线 | 小视频在线 | 老男人av| 中文字幕日韩精品无码内射 | 九九热这里有精品视频 |