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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

CSP认证201712-4行车路线[C++题解]:单源最短路变型、拆点、好题!

發布時間:2025/4/5 c/c++ 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 CSP认证201712-4行车路线[C++题解]:单源最短路变型、拆点、好题! 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

      • 題目解答
      • 題目鏈接

題目解答



來源:acwing

分析:
題目給定所有答案不超過1e6,其實也就保證了連續小路的長度不超過1000(1000的平方就是1e6)。這樣我們就可以在題目給定的條件下,枚舉出所有連續小路的情況。比如終點n號點,通向它的可能有m個點,其中有的是小路,有的是大路,我們可以分類來處理邊權。

我們用拆點來做這道題。 將每個點多拆出1001個點,意思是對最后一段的路況進行分情況討論,可能不是小路,長度是0;可能是小路,長度是2,3,…1000,很多種情況,反正題目給定最后的小路的長度不會超過1000. 而且只需要計算題目給定的數據即可。

Dist[i][j]Dist[i][j]Dist[i][j]表示從1到點i的最短距離,第二維j表示1到i點這條路徑上最后那段(連接i)的小路的長度。如果1到i的路徑最后那段是大路,那么j 置為0.

那最后的答案是什么呢? 是dist[n][i]dist[n][i]dist[n][i],枚舉每個i從0到1000,取出最小值即可。
具體分析如下圖:

這樣建邊的時候add函數需要考慮這條路的類型是什么,是大路還是小路。

ac代碼

#include<bits/stdc++.h> using namespace std; const int N = 510, M = 200010; const int INF = 1e6; int n, m; int h[N], e[M], ne[M], w[M], idx; int f[M];// 邊的類型,大路還是小路 bool st[N][1010]; int dist[N][1010];//第二維為拆點struct Node{// 含義:點的編號,最后一段小路的長度,1到x點的最短距離int x, y, v;// 小根堆(距離從小到大)bool operator<(const Node& t)const{return v > t.v;} };void add(int t, int a, int b, int c){e[idx] =b ,w[idx] = c, f[idx] = t,ne[idx] = h[a], h[a] = idx ++; }void dijkstra(){memset(dist, 0x3f, sizeof dist);priority_queue<Node> heap;heap.push({1, 0, 0});dist[1][0] = 0;while(heap.size()){auto t = heap.top();heap.pop();if(st[t.x][t.y]) continue;st[t.x][t.y] = true;for(int i = h[t.x]; ~i; i= ne[i]){int x = e[i], y = t.y;//最后一段小路的長度yif(f[i]){// 小路y += w[i]; //小路長度更新if(y <= 1000){ // 小路長度不會超過1000if(dist[x][y] > t.v - t.y * t.y + y * y){// 更新1到x點的最短路dist[x][y] = t.v - t.y * t.y + y * y; if(dist[x][y] <= INF){// 加入堆heap.push({x, y, dist[x][y]});}}}}else{ // 大路if(dist[x][0] > t.v + w[i]){dist[x][0] = t.v + w[i];//權值累加if(dist[x][0] <= INF)heap.push({x,0, dist[x][0]});}}}} }int main(){cin >> n >> m;memset(h, -1, sizeof h);while(m --){int t, a, b, c;cin >> t >> a >> b >> c;add(t, a, b, c), add(t, b, a, c);}dijkstra();int res = INF;// dist[n][i] 表示最后一段小路的長度為i的前提下,1到n的最短路// 我們通過dijkstra算法求得了合法的、最后一段是小路、但是小路長度不同的所有情況// 取min即可for(int i = 0; i <= 1000; i ++) res = min(res, dist[n][i]);cout << res << endl; }

題目鏈接

https://www.acwing.com/problem/content/3258/

總結

以上是生活随笔為你收集整理的CSP认证201712-4行车路线[C++题解]:单源最短路变型、拆点、好题!的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 日韩在线精品视频一区二区涩爱 | 色哟哟精品观看 | 成人在线播放av | 国产精品宾馆在线 | 在线观看成人av | jizzjizz亚洲| 亚洲高清毛片一区二区 | 99热com | 亚洲av综合永久无码精品天堂 | 光溜溜视频素材大全美女 | 欧美在线一 | 日本一区二区三区在线视频 | 日本美女性高潮 | av免费黄色| 韩国中文字幕在线观看 | 四虎毛片 | 黑人满足娇妻6699xx | 国产在线激情视频 | 国产黑丝一区 | 黄色片视频 | 在线中文字幕一区 | 91成人观看 | av网站在线观看免费 | 欧美黄色一级 | 操操操视频 | 亚洲熟妇一区二区三区 | av日韩一区二区三区 | 日本视频一区二区三区 | 8050午夜二级 | 日韩av麻豆 | 青青视频在线播放 | 玉米地疯狂的吸允她的奶视频 | 亚洲第一av | 加勒比一区在线 | 免费在线观看av片 | 成人二区三区 | 色亭亭| 精品少妇人妻一区二区黑料社区 | 成人av免费在线 | 天天视频亚洲 | 欧美在线二区 | 999zyz玖玖资源站永久 | www.4虎| 国内精品在线观看视频 | aaa在线播放 | 免费不卡视频 | 国产成人三级在线播放 | 蕾丝视频污 | 91视频大全 | 色综合五月 | 1000部啪啪未满十八勿入 | 天天干天天弄 | 中文字幕成人在线视频 | 国产日韩av在线播放 | 欧美色欧美| 88国产精品 | 国产精品国产成人国产三级 | 中文字幕麻豆 | 婷婷五月综合激情 | 欧美日韩国产大片 | 日本理论片午伦夜理片在线观看 | 操碰在线观看 | 国产日产欧洲无码视频 | 国产成人久久精品流白浆 | av观看网站| 激情黄色av | 97人妻精品一区二区三区免费 | 人人涩| 美国黄色一级视频 | 好吊操免费视频 | 超碰在线资源 | 依人成人综合网 | 国产黄色一区 | 成人性色生活片 | 丰满的人妻hd高清日本 | 免费在线看污 | 欧日韩在线 | 奇米超碰在线 | 国产精品视频网站 | 亚洲老妇色熟女老太 | 日韩电影在线观看中文字幕 | 日韩中文字幕观看 | 欧洲成人综合网 | 九色精品视频 | 精品1卡二卡三卡四卡老狼 日韩三级网 | 亚洲天堂日韩av | 国产精品视频在线观看免费 | 韩国av电影在线观看 | 羞视频在线观看 | 天堂网视频在线观看 | 不卡av免费在线观看 | 日产精品久久久久 | 日本成人三级 | 一眉道姑 | 日日摸夜夜添夜夜 | 妞干网精品 | 久久艹影院 | 森泽佳奈作品在线观看 | 中国xxxx性xxxx产国 |