精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

最短路怎么可能盡可能地長(zhǎng)呢?

開(kāi)發(fā) 前端
我們將數(shù)組傳入函數(shù) int dist[] ,不能使用 memset(dist, 0x3f, sizeof dist); 因?yàn)?dist 僅僅是一個(gè)指針,而非數(shù)組;我們的 dist 長(zhǎng)度為 N ,且為 int 類型,因此 memset(dist, 0x3f, N * 4)。

[[416100]]

本文轉(zhuǎn)載自微信公眾號(hào)「Piper蛋窩」,作者Piper蛋。轉(zhuǎn)載本文請(qǐng)聯(lián)系Piper蛋窩公眾號(hào)。

記錄一道題解, 題目來(lái)自 Acwing.com 第 11 場(chǎng)周賽.

https://www.acwing.com/activity/content/59/

沒(méi)參加. 如果讓我做的話我做不出來(lái), 難度是困難, 不是一道模板題, 用的知識(shí)點(diǎn) bfs 啥的都簡(jiǎn)單, 但是考的是分析能力.

我的筆記:

https://github.com/PiperLiu/ACMOI_Journey/tree/master/notes

最大化最短路[1]

給定一個(gè) 個(gè)點(diǎn) 條邊的無(wú)向連通圖。

圖中所有點(diǎn)的編號(hào)為 。

圖中不含重邊和自環(huán)。

指定圖中的 個(gè)點(diǎn)為特殊點(diǎn)。

現(xiàn)在,你必須選擇兩個(gè)特殊點(diǎn),并在這兩個(gè)點(diǎn)之間增加一條邊。

所選兩點(diǎn)之間允許原本就存在邊。

我們希望,在增邊操作完成以后,點(diǎn) 到點(diǎn) 的最短距離盡可能大。

輸出這個(gè)最短距離的最大可能值。

注意,圖中所有邊(包括新增邊)的邊長(zhǎng)均為 。

輸入格式

第一行包含三個(gè)整數(shù) 。

第二行包含 個(gè)整數(shù) ,表示 個(gè)特殊點(diǎn)的編號(hào), 之間兩兩不同。

接下來(lái) 行,每行包含兩個(gè)整數(shù) ,表示點(diǎn) 和點(diǎn) 之間存在一條邊。

輸出格式

一個(gè)整數(shù),表示最短距離的最大可能值。

數(shù)據(jù)范圍

前六個(gè)測(cè)試點(diǎn)滿足 。

所有測(cè)試點(diǎn)滿足 ,,,,。

輸入樣例1:

  1. 5 5 3 
  2. 1 3 5 
  3. 1 2 
  4. 2 3 
  5. 3 4 
  6. 3 5 
  7. 2 4 

輸出樣例1:

輸入樣例2:

  1. 5 4 2 
  2. 2 4 
  3. 1 2 
  4. 2 3 
  5. 3 4 
  6. 4 5 

輸出樣例2:

競(jìng)賽中等難度題目,重點(diǎn)在分析。

分析第一步,分情況討論。

題目中要求,必須在特殊點(diǎn)中選擇兩個(gè)點(diǎn),這兩個(gè)點(diǎn)之間會(huì)新增一條邊。優(yōu)化目標(biāo)是,新增邊后, 1 到 n 的最短路徑最大。

從 1 到 n 的最短路徑只可能有以下三種情況(如上圖):

  • 不經(jīng)過(guò) a to b 這條線
  • 經(jīng)過(guò) a -> b ,則距離是 x[a] + 1 + y[b]
  • 經(jīng)過(guò) b -> a ,則距離是 x[b] + 1 + y[a]
  • 說(shuō)明:x[a] 為 1 到 a 的距離,y[b] 為 n 到 b 的距離

如果我們?cè)?a 與 b 中增加一條邊,則最終最短路的距離為以下三者中取最小值:

  • 原有最短路長(zhǎng)度
  • x[a] + 1 + y[b]
  • x[b] + 1 + y[a]

我們沒(méi)辦法改變「原有最短路長(zhǎng)度」,因此只能希望 min(x[a] + 1 + y[b], x[b] + 1 + y[a]) 這個(gè)值越大越好。

因此,我們要考慮所有特殊點(diǎn)的兩兩組合,然后,找出最大的 min(x[a] + 1 + y[b], x[b] + 1 + y[a]) 的 a b 組合。

找兩兩組合

我們沒(méi)法直接找 min(x[a] + 1 + y[b], x[b] + 1 + y[a]) 的最大值,得進(jìn)行一步推導(dǎo):

  • x[a] + 1 + y[b] <= x[b] + 1 + y[a]
  • 即 x[a] - y[a] <= x[b] - y[b]
  • 即,當(dāng) x[a] - y[a] <= x[b] - y[b] 時(shí), min(x[a] + 1 + y[b], x[b] + 1 + y[a]) 為 x[a] + 1 + y[b]
  • 即,我們找 a, b 滿足 x[a] - y[a] <= x[b] - y[b] (這個(gè)約束條件也可使我們遍歷所有的 a, b 組合),使得 x[a] + 1 + y[b] 最大

找兩兩組合

如上,我們將特殊的點(diǎn)按照 x[i] - y[i] 升序排序;我們令 b 為第一層循環(huán):即首先確定 b 的位置(圖中為 i ) , a 的話,選擇選擇從起點(diǎn)到 i 的最大值即可,因?yàn)槲覀兊哪繕?biāo)是圖中紅色的線值最大,即 y[b] + 1 + x[a] 。

  1. #include <iostream> 
  2. #include <cstring> 
  3. #include <algorithm> 
  4. using namespace std; 
  5.  
  6. const int N = 2e5 + 10, M = 4e5 + 10; 
  7. int n, m, k; 
  8. int a[N], dist1[N], dist2[N];  // 特殊點(diǎn),題解中的x[]和y[] 
  9. int h[N], e[M], ne[M], idx; 
  10. int q[N];  // bfs 用的隊(duì)列 
  11.  
  12. void add(int a, int b) 
  13.     e[idx] = b, ne[idx] = h[a], h[a] = idx ++ ; 
  14.  
  15. void bfs(int st, int dist[]) 
  16.     int tt = 0, hh = 0; 
  17.     q[0] = st; 
  18.      
  19.     // 傳入?yún)?shù)的 dist 是一個(gè)指針 
  20.     // 不可以用 sizeof dist 
  21.     memset(dist, 0x3f, 4 * N); 
  22.     dist[st] = 0; 
  23.  
  24.     while (hh <= tt) 
  25.     { 
  26.         int t = q[hh ++]; 
  27.         // printf("t = %d h[t] = %d \n", t, h[t]); 
  28.          
  29.         for (int i = h[t]; ~i; i = ne[i]) 
  30.         { 
  31.             int j = e[i]; 
  32.             if (dist[j] > dist[t] + 1) 
  33.             { 
  34.                 dist[j] = dist[t] + 1; 
  35.                 // printf("dist[%d] = %d t = %d\n", j, dist[j], tt); 
  36.                 q[++ tt] = j; 
  37.             } 
  38.         } 
  39.     } 
  40.  
  41. int main() 
  42.     scanf("%d%d%d", &n, &m, &k); 
  43.     memset(h, -1, sizeof h);  // 莫忘! 
  44.     for (int i = 0; i < k; ++ i) 
  45.     { 
  46.         scanf("%d", &a[i]); 
  47.     } 
  48.     for (int i = 0; i < m; ++ i) 
  49.     { 
  50.         int x, y; 
  51.         scanf("%d%d", &x, &y); 
  52.         add(x, y); 
  53.         add(y, x); 
  54.     } 
  55.  
  56.     bfs(1, dist1); 
  57.     // printf("==bfs2\n"); 
  58.     bfs(n, dist2); 
  59.      
  60.     // 開(kāi)始按照題解來(lái),先按照 dist1[i] - dist2[i] 排序 
  61.     sort(a, a + k, [&](int a, int b "&") { 
  62.         return dist1[a] - dist2[a] < dist1[b] - dist2[b]; 
  63.     }); 
  64.      
  65.     // b 作為最外層循環(huán),找最大的 dist1[a] + 1 + dist2[b] 
  66.     int x = dist1[a[0]], res = 0;  // 對(duì)于第 b = 第一個(gè)點(diǎn),a 也只能為第 0 個(gè)點(diǎn)(這里 x 是題解中紅線的左上端點(diǎn)) 
  67.     for (int i = 1; i < k; i ++ ) 
  68.     { 
  69.         int t = a[i];  // 這里 dist2[t] 是題解中紅線的右下端點(diǎn) 
  70.         res = max(res, dist2[t] + 1 + x); 
  71.         x = max(dist1[t], x); 
  72.     } 
  73.      
  74.     // 最后與本來(lái)的最短路比較 
  75.     res = min(res, dist1[n]); 
  76.      
  77.     printf("%d", res); 

經(jīng)驗(yàn):

這里,我們將數(shù)組傳入函數(shù) int dist[] ,不能使用 memset(dist, 0x3f, sizeof dist); 因?yàn)?dist 僅僅是一個(gè)指針,而非數(shù)組;我們的 dist 長(zhǎng)度為 N ,且為 int 類型,因此 memset(dist, 0x3f, N * 4);

參考資料

[1]最大化最短路: https://www.acwing.com/problem/content/3800/

 

責(zé)任編輯:武曉燕 來(lái)源: Piper蛋窩
相關(guān)推薦

2022-04-02 08:06:30

無(wú)服務(wù)器Arm云供應(yīng)

2021-01-08 08:22:25

代碼應(yīng)用程序

2025-07-03 08:34:40

2024-01-10 11:39:32

數(shù)據(jù)中心碳排放服務(wù)器

2017-10-25 09:24:25

蘋(píng)果

2010-02-23 15:25:10

CentOS Apac

2014-12-29 13:02:55

Docker容器創(chuàng)建go語(yǔ)言

2013-01-08 13:32:31

SEO GTD

2021-06-17 09:20:51

華為工作三十而立

2023-04-05 23:04:30

Bing Chat微軟

2021-04-20 08:11:33

Css前端@property

2020-10-15 17:28:45

思科網(wǎng)絡(luò)創(chuàng)新

2024-05-20 00:00:00

2022-10-24 10:51:21

人工智能樓宇自動(dòng)化

2016-03-14 14:45:18

中華網(wǎng)

2021-03-10 09:50:15

算法Dijkstra短路問(wèn)題

2011-05-17 13:58:37

最短路徑

2013-10-15 16:07:41

Windows 7Windows 8

2010-11-03 11:13:27

職場(chǎng)

2016-02-02 10:03:15

chromeMaterial De
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

日韩中文字幕在线| 亚洲国产精品影院| 成人午夜在线观看| 欧美人妻一区二区| 亚洲婷婷伊人| 欧美日韩美女一区二区| 国产又粗又猛又爽又黄的网站| 精品人妻一区二区三区日产乱码| 中日韩男男gay无套| 在线日韩av观看| 91人人澡人人爽| 97成人超碰| 亚洲一级二级三级| 色噜噜色狠狠狠狠狠综合色一| 国产精品一区二区人人爽| 亚洲国产婷婷| 色偷偷88888欧美精品久久久| 中文字幕乱码在线人视频| 韩国美女久久| 亚洲综合无码一区二区| 色一情一乱一伦一区二区三欧美 | 欧美亚洲免费| 久久五月天色综合| 日本二区在线观看| 2021年精品国产福利在线| 欧美三级韩国三级日本三斤| 欧美三级在线观看视频| 成人三级网址| 国产精品系列在线| 精品午夜一区二区| 精品国产乱码久久久久久蜜臀网站| 久久精品综合| 69av在线播放| 久久综合色综合| 亚洲国产精品综合久久久| 国产一区二区激情| 欧美无人区码suv| 超碰成人在线免费| 日韩美女主播在线视频一区二区三区| 亚洲激情在线观看视频| 神马午夜在线视频| 亚洲中国最大av网站| 国产高清免费在线| 欧美激情免费| 国产精品欧美经典| 视频一区不卡| 成人一区二区不卡免费| 久久久精品人体av艺术| 精选一区二区三区四区五区| 黄色一级a毛片| 粉嫩欧美一区二区三区高清影视| 91嫩草免费看| 亚洲av无码一区二区三区dv | 色狠狠av一区二区三区| 日韩在线综合网| av男人的天堂在线观看| 亚洲地区一二三色| 777av视频| 国产在线拍揄自揄拍视频| 一区二区免费看| 欧美高清中文字幕| 国产乱妇乱子在线播视频播放网站| 一区二区三区欧美日韩| 国产视频在线观看网站| 毛片在线网址| 午夜精品久久久久久久99樱桃 | 蜜桃av在线播放| 精品久久中文字幕| 日本一区二区黄色| 韩国精品主播一区二区在线观看| 在线中文字幕不卡| 一区二区三区视频网| 日韩黄色三级| 日韩欧美123| av网页在线观看| 欧美精品第一区| 国产一区二区三区在线| 又色又爽的视频| 欧美阿v一级看视频| 欧美激情视频一区二区| 国偷自拍第113页| 欧美96一区二区免费视频| 成人激情免费在线| 丰满少妇高潮在线观看| 久久精品一区四区| 宅男噜噜99国产精品观看免费| 午夜dj在线观看高清视频完整版 | 国产精品专区在线| 亚洲欧洲日本韩国| 欧美天天综合网| 日本成人在线免费观看| 盗摄牛牛av影视一区二区| 亚洲女成人图区| 中文字幕无码日韩专区免费 | 欧美肥婆姓交大片| 精品免费囯产一区二区三区 | 91系列在线播放| 午夜影院在线视频| 国产精品日日摸夜夜摸av| 日韩视频一二三| 桃花岛成人影院| 日韩一区二区不卡| 91精品人妻一区二区三区| 91欧美在线| 欧美在线视频一二三| 国产伦精品一区二区三区视频痴汉| 99久久精品国产一区二区三区| 午夜精品一区二区三区在线观看| 欧美精品videossex少妇| 日本丰满少妇一区二区三区| 男人网站在线观看| 天天射—综合中文网| 人体精品一二三区| 亚洲AV无码一区二区三区少妇 | 日韩av中文字幕在线| 国产精品精品软件男同| 日本在线不卡视频一二三区| 国产精品一区免费观看| 毛片在线播放a| 91精品1区2区| 中文字幕丰满孑伦无码专区| 国产精品sm| 成人国产精品av| 91涩漫在线观看| 在线观看国产日韩| 蜜桃精品成人影片| 亚洲片区在线| 国产日韩欧美一区二区三区四区 | 成人精品久久| 日韩女优在线播放| 少妇精品视频一区二区| 久久无码av三级| www.国产二区| 久久伦理中文字幕| 国产一区二区三区中文 | 亚洲电影一级黄| 人妻体体内射精一区二区| 欧美**字幕| 久久男人的天堂| japanese国产| 中文字幕一区二区三区视频| 北条麻妃在线视频观看| 人人精品视频| 久久青草福利网站| 99久久精品国产成人一区二区 | 人交獸av完整版在线观看| 91久久国产综合久久| 国产亚洲无码精品| 亚洲香蕉网站| aa日韩免费精品视频一| 日本在线观看视频| 欧洲生活片亚洲生活在线观看| 亚洲av成人无码久久精品| 中文一区在线| 国模精品娜娜一二三区| 蜜桃麻豆影像在线观看| 日韩av在线免费播放| 永久免费看片在线播放| 97久久精品人人澡人人爽| 国产精品久久久久7777| 北条麻妃一区二区三区在线观看 | 少妇aaaaa| 韩日欧美一区二区三区| 一区二区三区四区五区精品| 97精品国产99久久久久久免费| 亚洲视频第一页| 日韩不卡视频在线| 国产欧美综合在线| 一区二区三区视频在线观看免费| 国产精品免费不| 国产成人精品av| www.视频在线.com| 91福利在线导航| 国产色无码精品视频国产| 日本女人一区二区三区| 四虎永久在线精品免费一区二区| 精品无人乱码一区二区三区| 伊人伊成久久人综合网站| 黄色av一级片| 日韩一区在线播放| 少妇欧美激情一区二区三区| 欧美日韩99| 精品久久久久久一区| 亚洲精品永久免费视频| 亚洲激情 国产| 中文字幕理论片| 亚洲日本青草视频在线怡红院 | 粉嫩高潮美女一区二区三区| 欧美久久久久久久久久久久久久| 群体交乱之放荡娇妻一区二区| 日本国产高清不卡| 色大18成网站www在线观看| 欧美一级高清片| 欧美日韩精品区| 久久久av毛片精品| 妺妺窝人体色www在线观看| 亚洲九九视频| 久久久久久精| 在线免费观看亚洲| 久久久久久高潮国产精品视| 欧美3p视频在线观看| 91精品国产欧美一区二区| 国产一级特黄aaa大片| 久久久激情视频| 天天久久综合网| 国产日韩欧美一区| 手机看片福利永久国产日韩| 国产精品久久久网站| 国产精品美女av| bl在线肉h视频大尺度| 国产亚洲美女久久| 一区二区自拍偷拍| 日韩欧美亚洲国产一区| 色欲人妻综合网| 久久久久久久久久美女| 不卡的一区二区| 日韩黄色在线观看| 久在线观看视频| 欧美+日本+国产+在线a∨观看| 精品欧美一区二区在线观看视频 | 国产小视频免费在线网址| 制服丝袜亚洲播放| 午夜精品一区二| 黄色一区二区三区| 熟女少妇a性色生活片毛片| 99久久99久久久精品齐齐| 国产欧美一区二| 视频一区二区国产| 400部精品国偷自产在线观看| 精品国产99| 国产综合动作在线观看| 精品一区二区三区四区五区| 国产精品白嫩初高中害羞小美女| 俄罗斯一级**毛片在线播放| 自拍偷拍亚洲精品| 爽爽视频在线观看| 欧美精品一区二区三区蜜桃| 国产老女人乱淫免费| 在线观看日韩电影| 久久午夜免费视频| 亚洲地区一二三色| 久久精品这里只有精品| 国产精品伦一区| 男女做爰猛烈刺激| 国产欧美一区二区精品婷婷 | 久久久久久久久久久电影| 免费的av网站| 成人精品免费网站| 国产一级二级视频| 成人动漫精品一区二区| wwwxxx色| 国产盗摄一区二区三区| 亚洲成人天堂网| 精品中文字幕一区二区| 黄色永久免费网站| 欧美aaa在线| 国产高清视频网站| 久久超碰97中文字幕| 91亚洲免费视频| 免费看日韩精品| 91看片在线免费观看| 日韩有码一区二区三区| 污污动漫在线观看| 奇米888四色在线精品| 黄色片在线免费| 免费在线看成人av| 欧美 日韩 国产 激情| 美女视频一区在线观看| 做a视频在线观看| 精品一区二区三区不卡| 成年网站免费在线观看| 日av在线不卡| 亚洲国产日韩在线一区| 成人性生交大片免费看中文| 任你躁av一区二区三区| 成人av一区二区三区| 国产大尺度视频| 久久久精品人体av艺术| 2019男人天堂| 亚洲人成在线播放网站岛国| 麻豆国产尤物av尤物在线观看| 五月激情综合色| 国内自拍视频在线播放| 欧洲亚洲精品在线| 国产精品毛片一区视频播| 日韩欧美国产午夜精品| 免费在线毛片| 色先锋资源久久综合5566| a视频在线免费看| 国内精品小视频| 黄色成人小视频| 国产成人精品福利一区二区三区| 免费成人蒂法| 亚洲欧美久久久久一区二区三区| 中文字幕一区二区三区在线视频| 日本中文字幕网址| 日韩电影免费在线看| 亚洲第一成肉网| 91丨九色porny丨蝌蚪| 亚洲天堂一级片| 婷婷综合久久一区二区三区| 中文字幕在线2019| 欧美电影免费提供在线观看| www.天堂在线| 日韩一区视频在线| 超碰成人av| 国产精品一区久久| 韩国女主播一区二区三区| 日韩电影免费观看在| 欧美a级片一区| 无尽裸体动漫2d在线观看| 成人av电影在线| 无码人中文字幕| 五月综合激情日本mⅴ| 999久久久久久| 亚洲少妇中文在线| 日本高清成人vr专区| 国产精品久久久久久久久借妻 | 91在线免费看片| 欧美激情在线精品一区二区三区| 91制片厂免费观看| 日本欧美一区二区三区乱码 | 欧美特大特白屁股xxxx| 99国产盗摄| 97精品97| 中文久久久久久| 粉嫩高潮美女一区二区三区| 欧美黑人猛猛猛| 精品视频在线免费观看| 五月婷婷伊人网| 欧美精品做受xxx性少妇| 国产成人免费视频网站视频社区| 免费在线成人av| 亚洲大片在线| 在线观看一区二区三区视频| 亚洲人成精品久久久久| 国产一级片一区二区| 亚洲精品一区二三区不卡| 91www在线| 亚洲精品免费一区二区三区| 日韩精品免费一区二区三区| 国产中文字幕免费观看| 国产91丝袜在线18| 久久无码精品丰满人妻| 91精品国产综合久久蜜臀| 一级毛片视频在线| 国产精品xxx视频| jvid福利在线一区二区| 欧美激情成人网| 91丨porny丨在线| 亚洲天堂日韩av| 亚洲色图50p| 免费成人美女女| 日韩欧美精品一区二区| 亚洲国内欧美| 在线免费观看日韩av| 日韩欧美福利视频| 色视频在线观看| 国产成人亚洲综合91| 国产欧美一区二区精品久久久| 欧美 日韩精品| 99国内精品久久| 日本一本在线观看| 尤物九九久久国产精品的特点 | 欧美大人香蕉在线| 五月天开心婷婷| 亚洲品质自拍视频| 国产色综合视频| 高清视频欧美一级| 欧美顶级毛片在线播放| 中国丰满人妻videoshd | 青春有你2免费观看完整版在线播放高清 | 亚洲欧美色婷婷| av久久网站| 99热这里只有精品7| 99综合电影在线视频| 天天干天天干天天| 亚洲人成电影网站| 经典三级一区二区| 亚洲精品一区国产精品| 狠狠色狠狠色综合日日91app| 国产在线一卡二卡| 日韩av中文字幕在线播放| 亚洲国产尤物| 久久久久久久久影视| 国产精品影视天天线| 亚洲熟女综合色一区二区三区| 中文字幕日韩在线播放| 精品中文在线| 欧美丰满熟妇xxxxx| 中文字幕一区二区三区在线观看 | 黄色av片三级三级三级免费看| 6080日韩午夜伦伦午夜伦| 麻豆理论在线观看| 亚洲一区影院| 波波电影院一区二区三区| 一级黄色在线观看| 久久成人在线视频| 久久综合五月婷婷| 亚洲在线观看网站|