【代码随想录Day57】图论Part08
拓扑排序精讲
题目链接/文章讲解:代码随想录
import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);// 读取文件数量 n 和依赖关系数量 mint n = scanner.nextInt();int m = scanner.nextInt();// 初始化记录文件依赖关系的列表和每个文件的入度数组List<List<Integer>> umap = new ArrayList<>(n); // 记录文件依赖关系int[] inDegree = new int[n]; // 记录每个文件的入度// 初始化 umap,每个文件的依赖列表for (int i = 0; i < n; i++) {umap.add(new ArrayList<>());}// 读取依赖关系for (int i = 0; i < m; i++) {int s = scanner.nextInt(); // 依赖的源文件int t = scanner.nextInt(); // 依赖的目标文件umap.get(s).add(t); // 记录s指向哪些文件inDegree[t]++; // t的入度加一,表示有一个文件依赖于t}// 使用 ArrayDeque 作为队列来进行拓扑排序Deque<Integer> queue = new ArrayDeque<>();// 将所有入度为0的文件加入队列for (int i = 0; i < n; i++) {if (inDegree[i] == 0) {queue.add(i); // 入度为0的文件可以作为开头}}// 存储拓扑排序结果List<Integer> result = new ArrayList<>();// 拓扑排序过程while (!queue.isEmpty()) {int cur = queue.poll(); // 当前选中的文件result.add(cur); // 将当前文件加入结果列表// 遍历当前文件指向的所有文件for (int file : umap.get(cur)) {inDegree[file]--; // 当前文件指向的文件入度-1if (inDegree[file] == 0) {queue.add(file); // 如果入度为0,则加入队列}}}// 检查是否完成了拓扑排序if (result.size() == n) {// 如果结果列表的大小等于文件数量,说明拓扑排序成功StringBuilder output = new StringBuilder();for (int i = 0; i < result.size(); i++) {output.append(result.get(i)); // 添加文件到输出if (i < result.size() - 1) {output.append(" "); // 添加空格分隔文件}}System.out.println(output); // 输出最终结果} else {// 如果结果列表的大小不等于文件数量,说明存在循环依赖System.out.println(-1);}}
}
dijkstra(朴素版)精讲
题目链接/文章讲解:代码随想录
import java.util.Arrays;
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);// 读取节点数量 n 和边的数量 mint n = scanner.nextInt();int m = scanner.nextInt();// 初始化图的邻接矩阵,使用 Integer.MAX_VALUE 表示无穷大int[][] grid = new int[n + 1][n + 1];for (int i = 1; i <= n; i++) {Arrays.fill(grid[i], Integer.MAX_VALUE);}// 读取边的信息,建立邻接矩阵for (int i = 0; i < m; i++) {int p1 = scanner.nextInt();int p2 = scanner.nextInt();int val = scanner.nextInt();// 存储边的权值,假设图是有向图grid[p1][p2] = Math.min(grid[p1][p2], val); // 保证边的权值最小}int start = 1; // 起始点int end = n; // 终点// 存储从起始点到每个节点的最短距离int[] minDist = new int[n + 1];Arrays.fill(minDist, Integer.MAX_VALUE);minDist[start] = 0; // 起始点到自身的距离为0// 记录每个节点是否被访问过boolean[] visited = new boolean[n + 1];// Dijkstra 算法主循环for (int i = 1; i <= n; i++) {// 1. 找到未访问的节点中最小距离的节点int cur = -1;int minVal = Integer.MAX_VALUE;for (int v = 1; v <= n; ++v) {if (!visited[v] && minDist[v] < minVal) {minVal = minDist[v];cur = v; // 记录当前节点}}// 如果所有节点都已访问,或剩下的节点不可达,则退出循环if (cur == -1) break;visited[cur] = true; // 2. 标记当前节点已被访问// 3. 更新未访问节点到起始点的距离for (int v = 1; v <= n; v++) {// 如果有边且未访问,更新最短距离if (!visited[v] && grid[cur][v] != Integer.MAX_VALUE) {minDist[v] = Math.min(minDist[v], minDist[cur] + grid[cur][v]);}}}// 输出结果System.out.println(minDist[end] == Integer.MAX_VALUE ? -1 : minDist[end]);}
}
相关文章:
【代码随想录Day57】图论Part08
拓扑排序精讲 题目链接/文章讲解:代码随想录 import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner new Scanner(System.in);// 读取文件数量 n 和依赖关系数量 mint n scanner.nextInt();int m scanner.nextInt()…...
记录一次mmpretrain训练数据并转onnx推理
目录 1.前言 2.代码 3.数据形态【分类用】 4.配置文件 5.训练 6.测试-分析-混淆矩阵等等,测试图片效果等 7.导出onnx 8.onnx推理 9.docker环境简单补充 1.前言 好久没有做图像分类了,于是想用商汤的mmclassification快速搞一波,发现已…...
shodan5,参数使用,批量查找Mongodb未授权登录,jenkins批量挖掘
查找美国安全局漏洞 nww.nsa.gov(美国安全局官方网站) net参数使用 搜索指定的ip网段 shodan search --limit 10 --fields ip_str,port net:208.88.84.0/24 (老美国家安全局的一个网段)可能直接访问不太行,可以使用host参数,得到域名再去…...
telnet 密码模式 访问路由器
telnet 密码访问华为路由器 模拟被访问路由 sy [Huawei]int g0/0/0 //选中 g0/0/0端口 [Huawei-GigabitEthernet0/0/0]ip add 192.168.1.1 24 //设置端口ip [Huawei]user-interface vty 0 4 //配置vty [Huawei-ui-vty0-4]set authentication password cipher huawei123 //设置…...
文心一言 VS 讯飞星火 VS chatgpt (380)-- 算法导论24.4 12题
十二、给出一个有效算法来解决 A x ⩽ b Ax⩽b Ax⩽b 的差分约束系统,这里 b b b 的所有元素为实数,而变量 x i x_i xi 中某个给定的子集是整数。如果要写代码,请用go语言。 文心一言: 差分约束系统问题通常用于解决带有约…...
Unity自定义数组在Inspector窗口的显示方式
了解 单行高度:EditorGUIUtility.singleLineHeight获取 PropertyField 控件所需的高度:EditorGUI.GetPropertyHeight属性是否在Inspector窗口展开:SerializedProperty.isExpanded可重新排序列表类:ReorderableList绘制纯色矩形:EditorGUI.Dr…...
ERC论文阅读(03)--SPCL论文阅读笔记(2024-10-29)
SPCL论文阅读笔记 论文中心思想 这篇论文是研究ERC任务的论文,作者提出了监督原型对比学习的方法用于ERC任务。 论文 EMNLP2022 paper “Supervised Prototypical Contrastive Learning for Emotion Recognition in Conversation” 现存问题 现存的使用监督对…...
Straightforward Layer-wise Pruning for More Efficient Visual Adaptation
对于模型中冗余的参数,一个常见的方法是通过结构化剪枝方法减少参数容量。例如,基于幅度值和基于梯度的剪枝方法。尽管这些方法在传统训练上通用性,本文关注的PETL迁移有两个不可避免的问题: 显著增加了模型存储负担。由于不同的…...
喜讯 | 创邻科技杭州电子科技大学联合实验室揭牌成立!
近日,杭州电子科技大学图书情报专业硕士行业导师聘任仪式暨杭电-创邻图技术与数字化联合实验室(图书档案文物数字云联合研发中心)揭牌仪式在杭州电子科技大学隆重举行。杭州电子科技大学原副校长吕金海、研究生院副院长潘建江,科研…...
海外媒体发稿:如何打造媒体发稿策略
新闻媒体的发稿推广策略对于提升品牌知名度、吸引流量以及增加收入非常重要。本文将介绍一套在21天内打造爆款新闻媒体发稿推广策略的方法。 第一天至第七天:明确目标和定位 在这个阶段,你需要明确你的目标和定位,以便为你的新闻媒体建立一个…...
PyTorch模型保存与加载
1.保存与加载的概念(序列化与反序列化) 模型训练完毕之后,肯定想要把它保存下来,供以后使用,不需要再次去训练。 那么在pytorch中如何把训练好的模型,保存,保存之后又如何加载呢? 这就用需要序列化与反序列化,序列化与反序列化的概念如下图所示: 因为在内…...
CH569开发前的测试
为了玩转准备Ch569的开发工作 ,准备了如下硬件和软件: 硬件 1.官方的 Ch569 开发板,官方买到的是两块插接在一起的;除了HSPI接口那里的电阻,这两块可以说是一样的。也意味着两块板子的开发也需要烧录两次;…...
MySQL中表的外连接和内连接
内连接和外连接 表的连接分为内连接和外连接,内连接就是将需要连接的表形成笛卡尔积筛选;外连接分为左外连接和右外连接,左外连接为左侧的表需要完全显示,右外连接为右侧的表现需要完全显示。 文章目录 内连接和外连接内连接外…...
Ubuntu 上安装 Redmine 5.1 指南
文章目录 官网安装文档:命令步骤相关介绍GemRubyRailsBundler 安装 Redmine更新系统包列表和软件包:安装必要的依赖:安装 Ruby:安装 bundler下载 Redmine 源代码:安装 MySQL配置 Redmine 的数据库配置文件:…...
从变量的角度理解 Hooks , 变得更简单了
从变量角度理解Hooks 在React的世界里,Hooks的引入为函数式组件带来了前所未有的灵活性和能力。它们让我们得以完全摆脱class式的写法,在函数式组件中完成生命周期管理、状态管理、逻辑复用等几乎全部组件开发工作。这次,我们就从变量的角度…...
LabVIEW Modbus通讯稳定性提升
在LabVIEW开发Modbus通讯程序时,通讯不稳定是一个常见问题,可能导致数据丢失、延迟或错误。为了确保通讯的可靠性,可以从多个角度进行优化,以下是一些有效的解决方案,结合实际案例进行分析。 1. 优化通讯参数设置 通讯…...
(8) cuda分析工具
文章目录 Nvidia GPU性能分析工具Nsight SystemNvidia GPU性能分析工具Nsight System Nvidia GPU性能分析工具Nsight System NVIDIA Nsight Systems是一个系统级的性能分析工具,用于分析和优化整个CUDA应用程序或系统的性能。它可以提供对应用程序整体性能的全面见…...
C语言 | Leetcode C语言题解之第517题超级洗衣机
题目: 题解: int findMinMoves(int* machines, int machinesSize){int sum0;for(int i0;i<machinesSize;i){summachines[i];}if(sum%machinesSize!0){return -1;}int psum/machinesSize;int ans0;int cur0;for(int i0;i<machinesSize;i){cur(mac…...
Java多线程编程基础
目录 编写第一个多线程程序 1. 方式一 : 继承Thread类, 重写run方法 2. 方式二: 实现Runnable接口, 重写run方法 3. 方式三: 使用Lambda表达式 [匿名内部类] [Lambda表达式] 在上个文章中, 我们了解了进程和线程的相关概念. 那么, 在Java中, 我们如何进行多线程编程呢? …...
刷代随有感(134):单调栈——下一个更大元素I(难点涉及哈希表与单调栈的结合)
单调栈处理的是下标! 题干: 代码: class Solution { public:vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {stack<int>ddst;unordered_map<int,int>umap;vector<int…...
reverse-shell工作原理深度解析:智能检测与多语言payload实现
reverse-shell工作原理深度解析:智能检测与多语言payload实现 【免费下载链接】reverse-shell Reverse Shell as a Service 项目地址: https://gitcode.com/gh_mirrors/re/reverse-shell reverse-shell作为一种强大的网络安全工具,其核心功能是让…...
告别YAML诅咒:用LLM自动生成可验证CD流水线(附奇点大会开源Schema v2.1)
更多请点击: https://intelliparadigm.com 第一章:AI原生持续交付:2026奇点智能技术大会部署流水线优化 在2026奇点智能技术大会上,AI原生持续交付(AI-Native CI/CD)成为核心实践范式——它不再将AI模型视…...
罗技PUBG压枪宏技术深度解析:硬件级输入控制的演进与挑战
罗技PUBG压枪宏技术深度解析:硬件级输入控制的演进与挑战 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 在FPS游戏竞技生态中&#…...
AI工具搭建自动化视频生成生成日志审计
1,它是个啥 其实就是拿AI当黑盒,把视频生成这件事拆成按脚本跑的一连串动作,然后全程记下谁在什么时候调了哪个模型、输出了啥、花了多少秒、花了多少钱。做这件事的人,多半是公司里管产研的那几位,他们怕的不是AI干砸…...
打车VS地铁VS共享单车?成本/时间/可靠性三维测评(实测17次,误差±12秒)
更多请点击: https://intelliparadigm.com 第一章:奇点智能技术大会公共交通路线 前往奇点智能技术大会主会场(上海张江科学会堂)的公共交通方案已全面优化,支持实时路径规划与多模态换乘。推荐使用「MetroBus步行」组…...
【硬件实战】串口通信排障指南:从RS-232到RS-422的链路诊断与修复
1. 串口通信故障排查的起点:物理层检查 当你面对一台死活不通信的设备时,先别急着怀疑人生。我经历过太多次这种场景:项目deadline就在眼前,现场客户盯着你调试,结果串口死活不出数据。这时候最忌讳的就是一上来就改波…...
创优必看!鲁班奖工程的八项基本要求
创优必看!鲁班奖工程的八项基本要求 作为建筑工程行业的最高级别奖项,鲁班奖的评选工作严格贯彻执行国家有关基本建设的法律、法规和方针政策,以及国家、行业现行的技术标准、施工规范和技术规程。那么,什么样的工程才能荣获鲁班奖呢? 本文根据《鲁班奖评选工作细则》总…...
QtMqtt模块编译实战:从源码到集成的关键步骤与排错指南
1. 为什么需要手动编译QtMqtt模块 MQTT协议在物联网领域应用广泛,但Qt官方发行版中并不包含MQTT模块。这就好比买了一台组装电脑,却发现显卡需要自己另外安装。QtMqtt模块作为Qt的扩展组件,目前需要通过源码编译的方式集成到开发环境中。 我去…...
如何3步搞定QQ音乐、网易云音乐加密文件,让你的音乐真正属于你
如何3步搞定QQ音乐、网易云音乐加密文件,让你的音乐真正属于你 【免费下载链接】unlock-music-electron Unlock Music Project - Electron Edition 在Electron构建的桌面应用中解锁各种加密的音乐文件 项目地址: https://gitcode.com/gh_mirrors/un/unlock-music-…...
77、【Agent】【OpenCode】bash 工具提示词(持久化)(一)
【声明】本博客所有内容均为个人业余时间创作,所述技术案例均来自公开开源项目(如Github,Apache基金会),不涉及任何企业机密或未公开技术,如有侵权请联系删除 背景 上篇 blog 【Agent】【OpenCode】用户对…...
