代码随想录算法训练营第六十五天| 图论10

ops/2025/3/19 8:36:25/

Bellman_ford 队列优化算法(又名SPFA)

代码随想录

import collectionsdef main():n, m = map(int, input().strip().split())edges = [[] for _ in range(n + 1)]for _ in range(m):src, dest, weight = map(int, input().strip().split())edges[src].append([dest, weight])minDist = [float("inf")] * (n + 1)minDist[1] = 0que = collections.deque([1])visited = [False] * (n + 1)visited[1] = Truewhile que:cur = que.popleft()visited[cur] = Falsefor dest, weight in edges[cur]:if minDist[cur] != float("inf") and minDist[cur] + weight < minDist[dest]:minDist[dest] = minDist[cur] + weightif visited[dest] == False:que.append(dest)visited[dest] = Trueif minDist[-1] == float("inf"):return "unconnected"return minDist[-1]if __name__ == "__main__":print(main())

bellman_ford之判断负权回路

代码随想录

import sysdef main():input = sys.stdin.readdata = input().split()index = 0n = int(data[index])index += 1m = int(data[index])index += 1grid = []for i in range(m):p1 = int(data[index])index += 1p2 = int(data[index])index += 1val = int(data[index])index += 1# p1 指向 p2,权值为 valgrid.append([p1, p2, val])start = 1  # 起点end = n    # 终点minDist = [float('inf')] * (n + 1)minDist[start] = 0flag = Falsefor i in range(1, n + 1):  # 这里我们松弛n次,最后一次判断负权回路for side in grid:from_node = side[0]to = side[1]price = side[2]if i < n:if minDist[from_node] != float('inf') and minDist[to] > minDist[from_node] + price:minDist[to] = minDist[from_node] + priceelse:  # 多加一次松弛判断负权回路if minDist[from_node] != float('inf') and minDist[to] > minDist[from_node] + price:flag = Trueif flag:print("circle")elif minDist[end] == float('inf'):print("unconnected")else:print(minDist[end])if __name__ == "__main__":main()

bellman_ford之单源有限最短路

代码随想录

def main():# 輸入n, m = map(int, input().split())edges = list()for _ in range(m):edges.append(list(map(int, input().split() )))start, end, k = map(int, input().split())min_dist = [float('inf') for _ in range(n + 1)]min_dist[start] = 0# 只能經過k個城市,所以從起始點到中間有(k + 1)個邊連接# 需要鬆弛(k + 1)次for _ in range(k + 1):update = Falsemin_dist_copy = min_dist.copy()for src, desc, w in edges:if (min_dist_copy[src] != float('inf') and min_dist_copy[src] + w < min_dist[desc]):min_dist[desc] = min_dist_copy[src] + wupdate = Trueif not update:break# 輸出if min_dist[end] == float('inf'):print('unreachable')else:print(min_dist[end])if __name__ == "__main__":main()


http://www.ppmy.cn/ops/166988.html

相关文章

进程间通信--匿名管道

进程间通信介绍 进程间通信目的 数据传输&#xff1a;一个进程需要将它的数据发送给另一个进程资源共享&#xff1a;多个进程之间共享同样的资源。通知事件&#xff1a;一个进程需要向另一个或一组进程发送消息&#xff0c;通知它&#xff08;它们&#xff09;发生了某种事件&…

网络安全运维应急响应与溯源分析实战案例

在日常运维过程中&#xff0c;网络安全事件时有发生&#xff0c;快速响应和精准溯源是保障业务稳定运行的关键。本文将通过一个实际案例&#xff0c;详细解析从发现问题到溯源定位&#xff0c;再到最终解决的完整流程。 目录 一、事件背景 二、事件发现 1. 监控告警触发 2…

后端 - java - - 权限修饰符

权限修饰符&#xff08;访问修饰符&#xff09;-- 控制类、方法、变量、构造函数的访问权限 1、public 所有成员皆可访问 用于库中的公共API接口或类 开放级别最高 2、protected 同一包中可访问 不同包中继承的子类可访问 用于继承场景&#xff0c;允许子类访问特定的字…

Git下载安装(保姆教程)

目录 1、Git下载 2、Git安装&#xff08;windows版&#xff09; &#xff08;1&#xff09;启动安装程序 &#xff08;2&#xff09;阅读许可协议 &#xff08;3&#xff09;选择安装路径 &#xff08;4&#xff09;选择组件 &#xff08;5&#xff09;选择开始菜单文件夹…

非洲能源商会:架起中非能源合作的桥梁

在全球能源转型与南南合作深化的背景下,非洲能源商会(African Energy Chamber,简称AEC) 以其独特的战略定位与实践成果,成为推动非洲能源发展与中非合作的关键力量。作为非洲领先的能源行业倡导组织,AEC自成立以来始终致力于促进非洲能源价值链的可持续发展,通过政策对话、行业…

python 入门笔记7-面向对象

1. 面向对象基础概念 类&#xff08;Class&#xff09;&#xff1a;对象的蓝图&#xff0c;定义对象的属性和方法。 对象&#xff08;Object&#xff09;&#xff1a;类的实例&#xff0c;具有具体的属性和行为。 属性&#xff08;Attribute&#xff09;&#xff1a;对象的状…

Pot-App 本地deepseek-r1 翻译开源插件,支持本地ollama deepseek-r1系列模型,同时在POT翻译窗口不显示模型思考过程

一、软件介绍 文末提供插件及源码下载 此开源插件作為支持本地ollama deepseek-r1系列模型&#xff0c;並在POT输出窗口中不显示模型思考过程。 模型安装&#xff08;根据自己的电脑配置安装相应版本&#xff0c;支持官方1.5b~8b&#xff09; Ollama模型网址&#xff1a;deep…

天梯赛 L2-005 集合相似度

很简单的一道L2&#xff0c;直接使用unoredred_map记录两个数组的交集和并集即可。 #include <bits/stdc.h> using namespace std; #define endl \n #define int long long typedef long long ll; const int N 1010; const int mod 998244353; void solve() {int n;ci…