标签:743 dist int 节点 延迟时间 vector INF 101 leetcode
单源最短路径,其实就是求某个节点到其他所有节点中路径的最大值
class Solution { public: void dijkstra(vector<vector<int>>& w, int k, int n,vector<bool>& vis,vector<int>& dist) { // 只有起点k最短距离为 0 dist[k] = 0; // 迭代 n 次, n表示一共n个节点 for (int p = 1; p <= n; p++) { // 每次找到「最短距离最小」且「未被更新」的点 t int t = -1; for (int i = 1; i <= n; i++) { if (!vis[i] && (t == -1 || dist[i] < dist[t])) t = i; } // 标记点 t 为已更新 vis[t] = true; // 用点 t 的「最小距离」更新其他点 for (int i = 1; i <= n; i++) { dist[i] = min(dist[i], dist[t] + w[t][i]); // cout<<i<<":" <<dist[i]<<endl; } } } int networkDelayTime(vector<vector<int>>& times, int n, int k) { // 数组的长度根据题目每个参数的最大值进行设定 vector<vector<int>> w(101,vector<int>(101)); int INF = 0x3f3f3f3f; // 起始先将所有的点标记为「未更新」和「距离为正无穷」 expected parameter declarator vector<bool> vis = vector<bool>(101, false); vector<int> dist = vector<int>(101, INF); // 初始化邻接矩阵 for (int i = 1; i <= n; i++) { for (int j = 1; j <= n; j++) { w[i][j] = w[j][i] = i == j ? 0 : INF; } } // 存图 for (auto t : times) { int u = t[0], v = t[1], c = t[2]; // cout<<"val:" <<u<<" "<<v<<" "<<c<<endl; w[u][v] = c; } dijkstra(w,k,n,vis,dist); int res = 0; for(int i = 1; i <= n; i++){ res = max(res, dist[i]); } return res > INF / 2 ? -1 : res; } };
标签:743,dist,int,节点,延迟时间,vector,INF,101,leetcode 来源: https://www.cnblogs.com/ymec/p/15311061.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。