当前位置: 首页 > news >正文

Java手写拓扑排序和拓扑排序应用拓展案例

Java手写拓扑排序和拓扑排序应用拓展案例

1. 算法思维导图

初始化入度表和邻接表
构建入度为0的节点队列
遍历队列 删除该节点的出边 更新入度表
如果被删除节点的出边节点入度为0 加入队列
重复步骤C和D 直到队列为空
判断是否有环 若有环则无法进行拓扑排序
输出拓扑排序结果

2. 该算法的手写必要性和市场调查

拓扑排序是一种常用的图算法,广泛应用于任务调度、编译器优化、依赖关系分析等领域。手写拓扑排序算法的必要性在于加深对该算法的理解,并能够根据具体需求进行灵活的定制和优化。市场调查显示,拓扑排序算法在软件开发和数据处理领域有着广泛的应用需求,对该算法的手写实现和优化能力有很高的市场价值。

3. 该算法的详细介绍和步骤

拓扑排序是一种基于有向无环图(DAG)的排序算法,通过对图中节点的依赖关系进行排序,使得所有的依赖关系都能够被满足。

步骤如下:

  1. 初始化入度表和邻接表:遍历图中的所有节点,记录每个节点的入度和出边节点。
  2. 构建入度为0的节点队列:将入度为0的节点加入队列。
  3. 遍历队列,删除该节点的出边,更新入度表:从队列中取出一个节点,遍历该节点的出边节点,将其入度减1,并更新入度表。
  4. 如果被删除节点的出边节点入度为0,加入队列:如果某个节点的入度减为0,则将其加入队列。
  5. 重复步骤3和4,直到队列为空。
  6. 判断是否有环,若有环则无法进行拓扑排序:如果图中存在入度不为0的节点,则说明图中存在环,无法进行拓扑排序。
  7. 输出拓扑排序结果:按照队列中节点的顺序,输出拓扑排序结果。

4. 该算法的手写实现总结和思维拓展

通过手写实现拓扑排序算法,可以更深入地理解该算法的原理和实现过程。在实现过程中,需要注意对入度表和邻接表的更新,以及对环的判断。思维拓展可以从以下几个方面进行:

  • 如何优化拓扑排序算法的时间复杂度?
  • 如何处理带权重的有向无环图的拓扑排序?
  • 如何处理有环图的拓扑排序需求?

5. 该算法的完整代码

import java.util.*;public class TopologicalSort {public static List<Integer> topologicalSort(int numCourses, int[][] prerequisites) {// 初始化入度表和邻接表int[] inDegree = new int[numCourses];List<List<Integer>> adjacency = new ArrayList<>();for (int i = 0; i < numCourses; i++) {adjacency.add(new ArrayList<>());}for (int[] prerequisite : prerequisites) {inDegree[prerequisite[0]]++;adjacency.get(prerequisite[1]).add(prerequisite[0]);}// 构建入度为0的节点队列Queue<Integer> queue = new LinkedList<>();for (int i = 0; i < numCourses; i++) {if (inDegree[i] == 0) {queue.offer(i);}}// 遍历队列,删除该节点的出边,更新入度表List<Integer> result = new ArrayList<>();while (!queue.isEmpty()) {int curr = queue.poll();result.add(curr);for (int next : adjacency.get(curr)) {inDegree[next]--;if (inDegree[next] == 0) {queue.offer(next);}}}// 判断是否有环,若有环则无法进行拓扑排序if (result.size() != numCourses) {return new ArrayList<>();}return result;}
}

6. 该算法的应用前景调研

拓扑排序算法在任务调度、编译器优化、依赖关系分析等领域有着广泛的应用前景。随着大数据、人工智能等技术的发展,对于处理复杂依赖关系的需求越来越多,拓扑排序算法的应用前景也越来越广阔。

7. 该算法的三个拓展应用案例

拓展应用案例1: 课程安排

public class CourseSchedule {public boolean canFinish(int numCourses, int[][] prerequisites) {int[] inDegree = new int[numCourses];List<List<Integer>> adjacency = new ArrayList<>();for (int i = 0; i < numCourses; i++) {adjacency.add(new ArrayList<>());}for (int[] prerequisite : prerequisites) {inDegree[prerequisite[0]]++;adjacency.get(prerequisite[1]).add(prerequisite[0]);}Queue<Integer> queue = new LinkedList<>();for (int i = 0; i < numCourses; i++) {if (inDegree[i] == 0) {queue.offer(i);}}int count = 0;while (!queue.isEmpty()) {int curr = queue.poll();count++;for (int next : adjacency.get(curr)) {inDegree[next]--;if (inDegree[next] == 0) {queue.offer(next);}}}return count == numCourses;}
}

拓展应用案例2: 任务调度

public class TaskScheduler {public int leastInterval(char[] tasks, int n) {int[] count = new int[26];for (char task : tasks) {count[task - 'A']++;}PriorityQueue<Integer> pq = new PriorityQueue<>(26, Collections.reverseOrder());for (int c : count) {if (c > 0) {pq.offer(c);}}int intervals = 0;while (!pq.isEmpty()) {List<Integer> temp = new ArrayList<>();for (int i = 0; i <= n; i++) {if (!pq.isEmpty()){int curr = pq.poll();if (curr > 1) {temp.add(curr - 1);}intervals++;if (pq.isEmpty() && temp.size() == 0) {break;}}for (int i : temp) {pq.offer(i);}}return intervals;}}
}

拓展应用案例3: 编译器优化

public class CompilerOptimization {public List<String> optimizeCompiler(List<String> dependencies) {Map<String, Integer> inDegree = new HashMap<>();Map<String, List<String>> adjacency = new HashMap<>();for (String dependency : dependencies) {String[] parts = dependency.split("->");String from = parts[0];String to = parts[1];inDegree.put(from, inDegree.getOrDefault(from, 0));inDegree.put(to, inDegree.getOrDefault(to, 0) + 1);adjacency.putIfAbsent(from, new ArrayList<>());adjacency.get(from).add(to);}Queue<String> queue = new LinkedList<>();for (String node : inDegree.keySet()) {if (inDegree.get(node) == 0) {queue.offer(node);}}List<String> result = new ArrayList<>();while (!queue.isEmpty()) {String curr = queue.poll();result.add(curr);if (adjacency.containsKey(curr)) {for (String next : adjacency.get(curr)) {inDegree.put(next, inDegree.get(next) - 1);if (inDegree.get(next) == 0) {queue.offer(next);}}}}return result;}
}

案例总结

拓扑排序是一种针对有向无环图(DAG)的排序算法,它可以将图中的节点按照依赖关系进行排序。拓扑排序在许多领域中都有广泛的应用,下面是一些常见的应用总结:

  1. 任务调度:在任务调度中,有些任务可能存在依赖关系,即某些任务必须在其他任务执行完成后才能开始。通过拓扑排序,可以确定任务的执行顺序,保证任务按照依赖关系进行调度。

  2. 课程安排:在学校或大学中,课程之间通常存在依赖关系,即某些课程必须在其他课程之前完成。拓扑排序可以帮助学校进行课程安排,确保学生按照正确的顺序学习课程。

  3. 编译顺序:在编译过程中,源代码中的模块或函数可能会相互调用,存在依赖关系。拓扑排序可以确定编译的顺序,确保每个模块都在其依赖的模块之后编译。

  4. 依赖关系管理:在软件开发中,模块或组件之间常常存在依赖关系。通过拓扑排序,可以管理和解决模块之间的依赖关系,以确保软件的正确构建和部署。

  5. 项目管理:在项目管理中,任务的前后关系和依赖关系是重要的考虑因素。通过拓扑排序,可以确定任务的执行顺序,从而帮助项目团队有效地计划和管理项目进度。

总之,拓扑排序在任务调度、课程安排、编译顺序、依赖关系管理和项目管理等方面都有重要的应用。它能够解决依赖关系问题,确保任务按照正确的顺序执行,提高效率和准确性。

相关文章:

Java手写拓扑排序和拓扑排序应用拓展案例

Java手写拓扑排序和拓扑排序应用拓展案例 1. 算法思维导图 #mermaid-svg-o8KpEXzxukfDM8c9 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-o8KpEXzxukfDM8c9 .error-icon{fill:#552222;}#mermaid-svg-o8KpEXzxukfD…...

练习:使用servlet显示试卷页面

试卷页面代码 在浏览器输入如下地址&#xff1a; http://localhost/examPageServlet 效果如下&#xff1a;...

视频监控系统/视频云存储EasyCVR接入国标GB28181设备无法播放设备录像,是什么原因?

安防视频监控平台EasyCVR支持将部署在监控现场的前端设备进行统一集中接入&#xff0c;可兼容多协议、多类型设备&#xff0c;管理员可选择任意一路或多路视频实时观看&#xff0c;视频画面支持单画面、多画面显示&#xff0c;视频窗口数量有1、4、9、16个可选&#xff0c;还能…...

四叶草clover配置工具:Clover Configurator for Mac

Clover Configurator是一款Mac上的工具&#xff0c;用于配置和优化Clover引导加载器。Clover引导加载器是一种用于启动macOS的开源引导加载器。它允许用户在启动时选择操作系统和配置启动选项。 Clover Configurator提供了一个可视化的界面&#xff0c;让用户可以轻松地编辑和…...

计算机网络第四章——网络层(中)

提示&#xff1a;待到山花烂漫时&#xff0c;她在丛中笑。 文章目录 需要加头加尾&#xff0c;其中头部最重要的就是加了IP地址和MAC地址&#xff08;也就是逻辑地址和物理地址&#xff09;集线器物理层设备&#xff0c;交换机是物理链路层的设备&#xff0c;如上图路由器左边就…...

时序分解 | MATLAB实现基于小波分解信号分解分量可视化

时序分解 | MATLAB实现基于小波分解信号分解分量可视化 目录 时序分解 | MATLAB实现基于小波分解信号分解分量可视化效果一览基本介绍程序设计参考资料 效果一览 基本介绍 基于小波分解的分量可视化&#xff0c;MATLAB编程程序&#xff0c;用于将信号分解成不同尺度和频率的子信…...

VMware虚拟化环境搭建

虚拟化环境搭建 1. 什么是虚拟化环境&#xff1f;未来工作中在何处使用&#xff1f; 在网络安全中&#xff0c;虚拟化环境是一种技术&#xff0c;它将一个物理计算机系统划分成多个独立、可管理的虚拟环境。这种虚拟环境技术允许多个完全不同的操作系统、显示装置和软件在同一…...

Jenkins :添加node权限获取凭据、执行命令

拥有Jenkins agent权限的账号可以对node节点进行操作&#xff0c;通过添加不同的node可以让流水线项目在不同的节点上运行&#xff0c;安装Jenkins的主机默认作为master节点。 1.Jenkins 添加node获取明文凭据 通过添加node节点&#xff0c;本地监听ssh认证&#xff0c;选则凭…...

如何实现不同MongoDB实例间的数据复制?

作为一种Schema Free文档数据库&#xff0c;MongoDB因其灵活的数据模型&#xff0c;支撑业务快速迭代研发&#xff0c;广受开发者欢迎并被广泛使用。在企业使用MongoDB承载应用的过程中&#xff0c;会因为业务上云/跨云/下云/跨机房迁移/跨地域迁移、或数据库版本升级、数据库整…...

微服务保护-隔离

个人名片&#xff1a; 博主&#xff1a;酒徒ᝰ. 个人简介&#xff1a;沉醉在酒中&#xff0c;借着一股酒劲&#xff0c;去拼搏一个未来。 本篇励志&#xff1a;三人行&#xff0c;必有我师焉。 本项目基于B站黑马程序员Java《SpringCloud微服务技术栈》&#xff0c;SpringCloud…...

报错:appium AttributeError: ‘NoneType‘ object has no attribute ‘to_capabilities‘

报错如下 Traceback (most recent call last):File "C:\Users\wlb\Desktop\test\python\2.py", line 16, in <module>driver webdriver.Remote("http://127.0.0.1:4723/wd/hub", caps)File "D:\software\python3\lib\site-packages\appium\we…...

MFC - 一文带你从小白到项目应用(全套1)

文章篇幅可能会比较长&#xff0c;从入门到基本能上项目的全部内容。建议观看的过程中&#xff0c;用电脑跟着学习案例。 持续输出优质文章是作者的追求&#xff0c;因为热爱&#xff0c;所以热爱。 最近看动漫被一句鸡汤感动到了&#xff0c;也送给各位朋友&#xff1a; 只要有…...

(2596. 检查骑士巡视方案leetcode,经典深搜)-------------------Java实现

&#xff08;2596. 检查骑士巡视方案leetcode,经典深搜&#xff09;-------------------Java实现 题目表述 骑士在一张 n x n 的棋盘上巡视。在 有效 的巡视方案中&#xff0c;骑士会从棋盘的 左上角 出发&#xff0c;并且访问棋盘上的每个格子 恰好一次 。 给你一个 n x n …...

Docker 部署 Bitwarden RS 服务

Bitwarden RS 服务是官方 Bitwarden server API 的 Rust 重构版。因为 Bitwarden RS 必须要通过 https 才能访问, 所以在开始下面的步骤之前, 建议先参考 《Ubuntu Nginx 配置 SSL 证书》 配置好域名和 https 访问。 部署 Bitwarden RS 拉取最新版本的 docker.io/vaultwarden…...

python与mongodb交互-->pymongo

from pymongo import MongoClient# 创建数据库连接对象 client=MongoClient(ip,27017)# 选择一个数据库 db=client[admin]db.authenticate(python,python)# 选择一个集合 col=client[pydata][test]col.insert({"class":"python"})col.find() for data in c…...

【网络】计算机网络基础

Linux网络 对网络的理解 在网络传输中存在的问题&#xff1a; 找到我们所需要传输的主机解决远距离数据传输丢失的问题怎么进行数据转发&#xff0c;路径选择的问题 有问题&#xff0c;就有解决方案&#xff1b; 我们把相同性质的问题放在一起&#xff0c;做出解决方案 解…...

(1)输入输出函数:cin和cout(2)数学函数:sqrt、pow、sin、cos、tan等

输入输出函数&#xff1a;cin 和 cout 在C编程语言中&#xff0c;为了与用户进行交互和显示程序的结果&#xff0c;我们使用了两个非常重要的函数&#xff1a;cin 和 cout。这两个函数分别用于输入和输出。 cin是C中的标准输入流对象&#xff0c;它用于从键盘接收用户的输入。…...

ArmSom-W3开发板之PCIE的开发指南(一)

1. 简介 RK3588从入门到精通本⽂介绍RK平台配置pcie的方法开发板&#xff1a;ArmSoM-W3 2、PCIE接口概述 PCIe&#xff08;Peripheral Component Interconnect Express&#xff09;是一种用于连接计算机内部组件的高速接口标准。以下是关于PCIe接口的简要介绍&#xff1a; …...

Android 13.0 framework修改AlertDialog对话框的button样式

1.概述 在13.0系统产品开发中 在AlertDialog 系统对话框原生的确定和取消 两个button 按钮中,由于产品觉得字体默认颜色的不太好看,由于产品的需求修改button字体的颜色,所以需要找到AlertDialog的字体样式然后修改就可以了 2.framework修改AlertDialog 对话框的button样式…...

如何使用ArcGIS Pro提取河网水系

DEM数据除了可以看三维地图和生成等高线之外&#xff0c;还可以用于水文分析&#xff0c;这里给大家介绍一下如何使用ArcGIS Pro通过水文分析提取河网水系&#xff0c;希望能对你有所帮助。 数据来源 本教程所使用的数据是从水经微图中下载的DEM数据&#xff0c;除了DEM数据&a…...

python pytesseract 中文文字批量识别

用pytesseract 来批量把图片转成文字 1、安装好 pytesseract 包 2、下载安装OCR https://download.csdn.net/download/m0_37622302/88348824https://download.csdn.net/download/m0_37622302/88348824 Index of /tesseracthttps://digi.bib.uni-mannheim.de/tesseract/ 我是…...

Python 之plt.plot()的介绍以及使用

文章目录 介绍代码实例 介绍 plt.plot() 是Matplotlib库中用于绘制线图&#xff08;折线图&#xff09;的主要函数之一。它的作用是将一组数据点连接起来&#xff0c;以可视化数据的趋势、关系或模式。以下是 plt.plot() 的详细介绍&#xff1a; plt.plot(x, y, fmt, **kwarg…...

自动化生成代码:MyBatis 的 Generator与MyBatis-Plus 的 AutoGenerator

文章目录 Mybatis Generator自动化生成代码MyBatis Generator概述使用Java代码形式1. 在 Maven 或 Gradle 中添加 MyBatis Generator 的依赖&#xff1a;2. 编写配置文件 GeneratorConfig.xml&#xff0c;配置需要生成的数据库表和对应的生成器&#xff1a;3. 在命令行中使用 M…...

达梦数据库-DW-国产化--九五小庞

武汉达梦数据库股份有限公司成立于2000年&#xff0c;是国内领先的数据库产品开发服务商&#xff0c;国内数据库基础软件产业发展的关键推动者。公司为客户提供各类数据库软件及集群软件、云计算与大数据等一系列数据库产品及相关技术服务&#xff0c;致力于成为国际顶尖的全栈…...

LeetCode 753. 破解保险箱【欧拉回路,DFS】困难

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…...

深度学习概念(术语):Fine-tuning、Knowledge Distillation, etc

文章目录 1.Fine-tuning (微调)2.Transfer Learning (迁移学习)3.Knowledge Distillation (知识蒸馏)4.Meta Learning (元学习) 这里的相关概念都是基于已有预训练模型&#xff0c;就是模型本身已经训练好&#xff0c;有一定泛化能力。需要“再加工”满足别的任务需求。 进入后…...

tcp_v4_connect函数的解析

源码&#xff1a; int tcp_v4_connect(struct sock *sk, struct sockaddr *uaddr, int addr_len) {// 解析输入的地址结构struct sockaddr_in *usin (struct sockaddr_in *)uaddr;// 获取 TCP 协议栈的全局 death_row 对象struct inet_timewait_death_row *tcp_death_row;// …...

go-channel

设计原理 Go 提及的设计模式就是&#xff1a;不要通过共享内存的方式进行通信&#xff0c;而是应该通过通信的方式共享内存。 共享内存方式&#xff1a;多个协程共享同一块内存&#xff0c;但是多个协程中读写变量是操作同一块内存&#xff0c;会产生多线程问题的并发问题&am…...

K8s操作命令

生命周期管理 1. 创建 1. 创建资源 kubectl run 创建并运行一个或多个容器镜像。*创建一个deployment或job来管理容器*。 语法&#xff1a;kubectl run NAME --imageimage [–env“keyvalue”] [–portport] [–replicasreplicas] [–dry-runbool] [–overridesinline-jso…...

【MySQL】 MySQL数据库基础

文章目录 &#x1f431;‍&#x1f453;数据库的操作&#x1f4cc;显示当前的数据库&#x1f4cc;创建数据库&#x1f388;语法&#xff1a;&#x1f388;语法说明&#x1f388;示例&#xff1a; &#x1f334;使用数据库&#x1f38b;删除数据库&#x1f431;‍&#x1f3cd;语…...

.net网站制作/廊坊网站建设公司

1LRC电路 有一个LRC电路连接电容电感如上&#xff0c;电压VV0Cos(ωt)VV_{0}Cos(\omega t)VV0​Cos(ωt) 以此建立方程 VCIR−V0Cos(ωt)−LdIdtV_{C}IR-V_{0}Cos(\omega t)-L\frac{dI}{dt} VC​IR−V0​Cos(ωt)−LdtdI​ IdQdtI\frac{dQ}{dt} IdtdQ​ VCQCV_{C}\frac{Q}{C} V…...

百度网页下载/简阳seo排名优化培训

概述 1. 什么是 Docker&#xff1f; Docker 是一个应用容器平台&#xff0c;管理项目中用到的所有环境&#xff08;MySQL、Redis…&#xff09; 2. Docker 和虚拟机的区别 虚拟机是携带操作系统的&#xff0c;本身很小的应用程序因为携带了操作系统而变得十分笨重&#xff0…...

建设银行建湖支行官方网站/seo搜索是什么

下午密码键盘返回了一个校验码&#xff0c;是BYTE类型数组&#xff0c;给上层应用返回最好是字符串方式&#xff0c;怎样原样的将BYTE数组转为string串呢&#xff1f;不多说&#xff0c;开动脑筋上手干&#xff01;&#xff01;&#xff01; BYTE格式的数组bt{08,D7,B4,FB}&…...

做网站是那个语言写的/金华网站推广

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼ShowWindow(hWnd, iCmdShow);UpdateWindow(hWnd);while (GetMessage(&msg, NULL, 0, 0)){TranslateMessage(&msg);DispatchMessage(&msg);}return msg.wParam;}LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPA…...

盐城哪家做网站的正规/上海网络推广联盟

尽管在PCB电路板生产中实行严格的工艺管理,但在实际的生产过程中&#xff0c;常出现一些与工艺要求不符的不良状况&#xff0c;根据全面质量管理的标准和要求&#xff0c;就需要将这些不良品分检出来&#xff0c;并对这些不良进行分析和处理。认知PCB生产中的质量管控(1) PCB生…...

mip手机网站模板/新闻发稿平台有哪些?

前段时间&#xff0c;进行USB拷贝方面的测试&#xff0c;积累了几个测试脚本&#xff0c;也可以进行磁盘间的拷贝&#xff0c;放在这里备份。 主要实现功能&#xff1a; 从一个存储设备拷贝数据到另一个位置&#xff0c;并比较两次拷贝的数据是否一致&#xff0c;并判断系统是…...