AcWing 849. Dijkstra求最短路 I

給定一個?n 個點?m 條邊的有向圖,圖中可能存在重邊和自環,所有邊權均為正值。

請你求出?11?號點到?n?號點的最短距離,如果無法從?1?號點走到?n?號點,則輸出??1。

輸入格式

第一行包含整數?n?和?m。

接下來?m?行每行包含三個整數?x,y,z,表示存在一條從點?x?到點?y 的有向邊,邊長為?z。

輸出格式

輸出一個整數,表示?1?號點到?n?號點的最短距離。

如果路徑不存在,則輸出??1。

數據范圍

1≤n≤500
1≤m≤10^5
圖中涉及邊長均不超過10000。

輸入樣例:
3 3
1 2 2
2 3 1
1 3 4
輸出樣例:
3

?

#include<stdio.h>
#include<string.h>
int state[100005];
int dis[100005];
int e[100005];
int ne[100005];
int head[100005];
int w[100005];
int idx=1;
int n,m;
int min(int a,int b) {if(a<b)return a;else {return b;}
}
void dijsktra() {dis[1]=0;for(int i=1; i<=n; i++) {int t=-1;for(int j=1; j<=n; j++) {if(!state[t]&&(t==-1||dis[t]>dis[j])) {t=j;}}state[t]=1;for(int u=head[t]; u!=-1; u=ne[u]) {int j=e[u];dis[j]=min(dis[j],dis[t]+w[u]);}}
}
void addedge(int a,int b,int c) {e[idx]=b;w[idx]=c;ne[idx]=head[a];head[a]=idx++;}
int main() {memset(dis,0x3f,sizeof(dis));memset(head,-1,sizeof(head));scanf("%d",&n);scanf("%d",&m);for(int i=1; i<=m; i++) {int u,v,w;scanf("%d",&u);scanf("%d",&v);scanf("%d",&w);addedge(u,v,w);}if (dis[m] == 0x3f3f3f) printf("-1");else {printf("%d",dis[m]);}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/43564.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/43564.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/43564.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python從Excel表中查找指定數據填入新表

#讀取xls文件中的數據 import xlrd file "原表.xls" wb xlrd.open_workbook(file) #讀取工作簿 ws wb.sheets()[0] #選第一個工作表 data [] for row in range(7, ws.nrows): name ws.cell(row, 1).value.strip() #科室名稱 total1 ws.cell(row, 2…

TIA博途與威綸通觸摸屏無實物仿真調試的具體方法示例

TIA博途與威綸通觸摸屏無實物仿真調試的具體方法示例 準備條件: TIA PORTAL V16 S7-PLCSIM V16 EasyBuilderPro V6.9.1 NetToPLCsim V1.2.5 如有需要,可以在這個鏈接中下載 NetToPLCSim - Browse Files at SourceForge.net538 weekly downloads3 weekly downloads12 weekly d…

QTransform 解析

實例: 以點(100,100) 圍繞點(200,150)旋轉45后的坐標, 采用QTransform 類方法實現移動變換. Test1 采用一個QTransform 對象,通過連續的變換后,發現最后的結果與預先的不一致. 原因: 當trans1.translate(-200., -150.); 后,坐標系的原點變成了-200,-150. 之后trans1.rotat…

LoveDA: 遙感土地覆蓋數據集的領域自適應語義分割

引入了土地覆蓋域自適應語義分割(LoveDA)數據集來推進語義和可轉移學習。LoveDA數據集包含來自三個不同城市的5987張高分辨率圖像和166768個帶注釋的對象。與現有數據集相比&#xff0c;LoveDA數據集包含兩個領域(城市和農村)&#xff0c;這帶來了相當大的挑戰&#xff0c;因為…

華為OD機試題-貪心歌手

題目解析 題目描述&#xff1a; 歌手準備從 A 城去 B 城參加演出 按照合同&#xff0c;他必須在 T 天內趕到。歌手途徑 N 座城市。歌手不能往回走。每兩座城市之間需要的天數都可以提前獲知。歌手在每座城市都可以在路邊賣唱賺錢。經過調研&#xff0c;歌手提前獲知了每座城市…

C# AOP面向切面編程

AOP&#xff08;Aspect-Oriented Programming&#xff0c;面向切面編程&#xff09;是一種編程范式&#xff0c;旨在將橫切關注點&#xff08;Cross-cutting Concerns&#xff09;從業務邏輯中分離出來。在傳統的面向對象編程中&#xff0c;橫切關注點&#xff08;如日志記錄、…

R包:蛋白質組學質控評估PTXQC包

介紹 PTXQC包是2016年發表在J Proteome Res期刊上的R包&#xff0c;它主要是對MaxQuant輸出結果進行提取處理從而獲得評估蛋白質質量結果。 安裝 從github安裝&#xff0c;安裝過程會自動構建tutorial。 devtools::install_github("cbielow/PTXQC", build_vignet…

AI數字人直播saas系統源碼部署火爆!無人直播系統全攻略

隨著直播行業的日益興盛&#xff0c;各種直播模式和玩法不斷涌現。其中&#xff0c;AI數字人直播更是憑借著其在降本增效的獨特優勢而在眾多直播模式中脫穎而出&#xff0c;成為了眾多企業已經引進或計劃引進的新型技術。而各大數字人源碼廠商推出的AI數字人直播saas系統源碼部…

面試題07-09

知道了 InnoDB 的索引實現后&#xff0c;就很容易明白為什么不建議使用過長的字段作為主鍵&#xff0c;因為所有輔助索引都引用主索引&#xff0c;過長的主索引會令輔助索引變得過大。再例如&#xff0c;用非單調的字段作為主鍵在 InnoDB 中不是個好主意&#xff0c;因為 InnoD…

走拼箱貨必看海運拼箱的實用技巧

在國際海運運輸中&#xff0c;海運拼箱適用于貨物數量較少或體積不足以填滿整個集裝箱的情況。 海運拼箱貨物通常由物流公司或貨代進行組織和管理。多個貨主的貨物通過合理拼裝&#xff0c;使集裝箱空間得到充分利用。 那么&#xff0c;在海運拼箱和整柜有哪些不同&#xff0c…

Linux -- 認識gcc/g++、代碼的編譯過程

目錄 前言&#xff1a; 使用 gcc/g&#xff1a; 代碼的編譯過程&#xff1a; 預處理&#xff1a; 頭文件展開&#xff1a; 宏替換去注釋&#xff1a; ?編輯 條件編譯&#xff1a; 編譯&#xff1a; 匯編&#xff1a; 鏈接&#xff1a; 動態庫&#xff08;動態鏈…

使用Simulink基于模型設計(二):系統定義和布局

Simulink模型的頂層系統布局是許多工程團隊可以使用的公共環境&#xff0c;是基于模型的設計范式&#xff1a;分析、設計、檢驗和實現。您可以通過確定模型的結構和各個組件來定義頂層系統。然后&#xff0c;您可以將模型按照層次結構進行組織&#xff0c;分別與系統的各個組件…

【鴻蒙學習筆記】交互事件

官方文檔&#xff1a;交互事件 目錄標題 分類交互事件-觸屏交互事件-手勢事件單一手勢 分類 交互事件-觸屏 在組件上按下(Down) , 滑動(Move) , 抬起(up)時觸發的回調事件。包括點擊事件、觸摸事件和拖拽事件 交互事件-手勢事件 在手機上點擊打開應用 , 長按后拖動應用 , 這…

自動化數據集成的BI工具,為你提供決策洞察力

傳統的商業智能&#xff08;BI&#xff09;報表系統采用的是“業務提報表需求&#xff0c;IT進行開發”的模式。決策管理者和業務人員提出用報表等來展示經營管理數據的需求&#xff1b;接著IT響應需求&#xff0c;進行需求溝通、數據處理加工、報表開發等主體工作&#xff1b;…

使用java代碼取本月第一個工作日

根據參數或當前月&#xff0c;獲取本月第一個工作日 文章目錄 根據參數或當前月&#xff0c;獲取本月第一個工作日前言一、根據當前日期獲取當前月的第一個工作日二、根據參數日期&#xff0c;獲取參數月的第一個工作日。總結 前言 這里我們列舉兩個方法&#xff1a; 1、沒有參…

RFID資產管理系統 RFID固定資產管理系統

大多數企業都曾被固定資產管理“難”的問題困擾&#xff1a;賬物不符、查詢不便、盤點耗時……因此&#xff0c;越來越多的企業選擇用資產管理系統&#xff0c;來實現資產智能化管理。 RFID資產管理系統方案是針對大多數企業存在的資產管理痛點&#xff0c;采用RFID技術&#…

uni-app三部曲之三: 路由攔截

1.引言 路由攔截&#xff0c;個人理解就是在頁面跳轉的時候&#xff0c;增加一級攔截器&#xff0c;實現一些自定義的功能&#xff0c;其中最重要的就是判斷跳轉的頁面是否需要登錄后查看&#xff0c;如果需要登錄后查看且此時系統并未登錄&#xff0c;就需要跳轉到登錄頁&…

Python地震波逆問題解構算法復雜信號分析

&#x1f3af;要點 &#x1f3af;時域、時頻域以及時間和頻率相關聯偏振特性分析三種算法 | &#x1f3af;時域波參數估計算法 | &#x1f3af;機器學習模型波形指紋分析算法 | &#x1f3af;色散曲線和頻率相關波分析算法 | &#x1f3af;動態傾斜校正算法 | &#x1f3af;聲…

【JS|第21期】JavaScript模塊化:深入解析三種文件暴露方式

日期:2024年7月6日 作者:Commas 簽名:(? ?_?)? 積跬步以致千里,積小流以成江海…… 注釋:如果您覺得有所幫助,幫忙點個贊,也可以關注我,我們一起成長;如果有不對的地方,還望各位大佬不吝賜教,謝謝^ - ^ 1.01365 = 37.7834;0.99365 = 0.0255 1.02365 = 1377.4083…

前后端項目部署方案匯總

前端項目 1、本地打包部署 # 本地打包部署到線上服務器 npm run build && \ rsync -r ./dist/* root127.0.0.1:/www/www.demo.com/www2、服務器端打包部署 步驟 拉取代碼 -> 安裝依賴 -> 打包編譯 -> 拷貝到運行目錄 -> 發送成功消息shell命令 git pu…