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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Luogu 3008 [USACO11JAN]道路和飞机Roads and Planes

發(fā)布時(shí)間:2025/7/14 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Luogu 3008 [USACO11JAN]道路和飞机Roads and Planes 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

BZOJ2200

聽(tīng)說(shuō)加上slf優(yōu)化的spfa的卡過(guò),真的不想寫(xiě)這些東西。

考慮使用堆優(yōu)化的dij算法。

先加上所有雙向邊,然后dfs一下搜出所有由雙向邊構(gòu)成的聯(lián)通塊,然后加上所有的單向邊,一邊對(duì)所有聯(lián)通塊拓?fù)渑判蛞贿呍诼?lián)通塊內(nèi)部處理最短路,因?yàn)樗械碾p向邊都是不帶負(fù)權(quán)的,而單向邊都是有負(fù)權(quán)的,所以這樣規(guī)避dij貪心的錯(cuò)誤之處。

注意到一個(gè)$inf$可能被另一個(gè)$inf$加上一個(gè)負(fù)權(quán)邊拓展得到,所以最后的答案可能會(huì)小于$inf$,檢驗(yàn)的時(shí)候注意取的極大值要小于一開(kāi)始賦的$inf$。

時(shí)間復(fù)雜度$O(nlogn)$。

Code:

#include <cstdio> #include <cstring> #include <queue> #include <iostream> #include <vector> using namespace std; typedef pair <int, int> pin;const int N = 25005; const int M = 2e5 + 5; const int inf = 1e8;int n, m1, m2, st, tot = 0, head[N], dis[N]; int l = 1, r = 0, q[N], deg[N], sccCnt = 0, bel[N]; bool vis[N]; vector <int> scc[N];struct Edge {int to, nxt, val; } e[M];inline void add(int from, int to, int val) {e[++tot].to = to;e[tot].val = val;e[tot].nxt = head[from];head[from] = tot; }template <typename T> inline void read(T &X) {X = 0; char ch = 0; T op = 1;for(; ch > '9'|| ch < '0'; ch = getchar())if(ch == '-') op = -1;for(; ch >= '0' && ch <= '9'; ch = getchar())X = (X << 3) + (X << 1) + ch - 48;X *= op; }void dfs(int x) {bel[x] = sccCnt, scc[sccCnt].push_back(x);for(int i = head[x]; i; i = e[i].nxt) {int y = e[i].to;if(!bel[y]) dfs(y);} }priority_queue <pin> Q; void dij(int c) {for(unsigned int i = 0; i < scc[c].size(); i++) Q.push(pin(-dis[scc[c][i]], scc[c][i]));for(; !Q.empty(); ) {int x = Q.top().second; Q.pop();if(vis[x]) continue;vis[x] = 1;for(int i = head[x]; i; i = e[i].nxt) {int y = e[i].to;if(bel[y] == c) {if(dis[y] > dis[x] + e[i].val) {dis[y] = dis[x] + e[i].val;Q.push(pin(-dis[y], y));}} else {if(dis[y] > dis[x] + e[i].val) dis[y] = dis[x] + e[i].val;deg[bel[y]]--;if(!deg[bel[y]]) q[++r] = bel[y]; }}} }int main() {read(n), read(m1), read(m2), read(st);for(int x, y, v, i = 1; i <= m1; i++) {read(x), read(y), read(v);add(x, y, v), add(y, x, v);}for(int i = 1; i <= n; i++)if(!bel[i]) ++sccCnt, dfs(i);for(int x, y, v, i = 1; i <= m2; i++) {read(x), read(y), read(v);add(x, y, v);deg[bel[y]]++;}for(int i = 1; i <= sccCnt; i++)if(!deg[i]) q[++r] = i;memset(dis, 0x3f, sizeof(dis)); dis[st] = 0;for(; l <= r; ++l) dij(q[l]);for(int i = 1; i <= n; i++) {if(dis[i] > inf) puts("NO PATH");else printf("%d\n", dis[i]);}return 0; } View Code

?

轉(zhuǎn)載于:https://www.cnblogs.com/CzxingcHen/p/9562972.html

總結(jié)

以上是生活随笔為你收集整理的Luogu 3008 [USACO11JAN]道路和飞机Roads and Planes的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 激情午夜影院 | 日韩av不卡在线播放 | 日韩中文在线一区 | 五月深爱婷婷 | 无码精品一区二区三区在线 | 久久网站av | 亚洲一区二区网站 | 色播在线| 国产av剧情一区二区三区 | 少妇姐姐 | 福利社区一区二区 | 国产精品免费视频观看 | 日韩中文字幕免费观看 | 欧美精品成人一区二区在线观看 | 久久蜜桃精品 | 亚洲中文字幕无码爆乳av | 五月激情婷婷在线 | 亚洲毛茸茸 | 夜夜草| 亚洲精品久久久乳夜夜欧美 | 国产免费无遮挡 | 91色交| 免费观看毛片网站 | v在线 | 青青草91| av男人的天堂在线 | 最新免费黄色网址 | 久久亚洲AV成人无码一二三 | 外国av网站| 少妇精品视频一区二区 | 国产一区二区在线观看视频 | 欧美午夜精品一区二区蜜桃 | 尤物久久| www,xxx日本| 在线亚洲+欧美+日本专区 | 国产精品v亚洲精品v日韩精品 | 男女深夜福利 | 亚洲性精品 | 电影寂寞少女免费观看 | 国产精品麻豆一区二区三区 | 男女吻胸做爰摸下身 | 欧美一a一片一级一片 | 四季av一区二区凹凸精品 | 久久丁香网 | 色婷婷午夜 | 色综合久久av | 91肉色超薄丝袜脚交一区二区 | 国产美女菊爆在线播放APP | 午夜时刻免费入口 | 国产乱人伦app精品久久 | 国产小视频在线观看免费 | 久久精品欧美一区二区 | 在线免费av观看 | 一级黄色免费 | 婷婷在线免费观看 | 在线看片成人 | 天天久| 香蕉视频黄污 | 免费黄色小网站 | 打开免费观看视频在线 | 不卡中文字幕av | 午夜蜜桃视频 | 精品国产福利 | 美女扒开大腿让男人桶 | 美女天天操 | 欧日韩在线视频 | 亚欧洲精品视频 | 亚洲午夜久久久久久久久红桃 | 欧美三区在线观看 | 91精品国产综合久久国产大片 | 亚洲综合专区 | 超碰在线人人草 | 免费日韩一区二区 | 国产在线免费观看 | 美女日批在线观看 | 亚洲图片在线播放 | 欧美成人三级视频 | 美人被强行糟蹋np各种play | 亚洲免费观看高清在线观看 | 蜜臀av免费一区二区三区水牛 | 国产精品综合久久 | 亚洲高清在线观看视频 | 国模私拍一区二区 | 日人视频 | 国产高清久久久 | 91禁蘑菇在线看 | 中文字幕在线网站 | 成人在线不卡视频 | 麻豆亚洲av熟女国产一区二 | 亚洲图片视频小说 | 伊人草 | 泰坦尼克号3小时49分的观看方法 | 久久精品www人人爽人人 | 一区二区视频免费在线观看 | 右手影院亚洲欧美 | 天堂网2018 | 久久综合一本 | 蜜桃久久久aaaa成人网一区 | 9i在线看片成人免费 |