OD 算法题 B卷【服务启动】

文章目录

  • 服务启动

服务启动

  • 有若干连续编号的服务(编号从0开始),服务间有依赖关系,启动一个指定的服务,请判断该服务是否可以成功启动,并输出依赖的前置服务编号;
  • 依赖关系是可以传递的,如2->1, 1->0, 则2依赖1和0;

输入描述:
第一行输入N,为服务的总个数,N在【1,5000】;
第二行输入M, 为指定启动的服务编号,M在【0, 5000);
接下来的N行为依赖关系,第一行为服务0的依赖,第二行为服务1的依赖,依次类推,格式:依赖服务个数,依赖编号,依赖编号…

输出描述:
如果服务无法启动(循环依赖)或者其他异常,输出-1
若可以启动,则按照编号从小到大顺序输出依赖的前置服务;若无依赖,则输出null

示例1
输入:
4
2
0
1,0
1,1
2,0,1
输出:
0,1

示例2
输入:
2
1
1,1
1,0
输出:
-1

python实现

  • DFS, 递归函数栈

# 输入
n = int(input().strip())
specific_m = int(input().strip())
# 依赖关系
depend_dict = {}
for i in range(n):depend_dict[i] = list(map(int, input().strip().split(",")))# 依赖的列表
depend_list = []def dfs(m):global depend_dict, depend_list, specific_mcur_data = depend_dict.get(m)if  cur_data[0] == 0:  # 没有依赖关系,可以启动returnelse:for i in range(1, len(cur_data)):# 处理循环依赖if cur_data[i] == specific_m or cur_data[i] in depend_list:raise ValueError("循环依赖,无法启动")# 存储依赖depend_list.append(cur_data[i])# 递归调用dfs(cur_data[i])# 调用dfs
try:if n < 1 or n > 5000:raise ValueError("n 超出范围")elif specific_m < 0 or n >= 5000:raise ValueError("m 超出范围")dfs(specific_m)if depend_list:  # 可以启动,并有前置依赖服务depend_list.sort()print(",".join([str(i) for i in depend_list]))else:print("null")
except ValueError:print(-1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/82492.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

StarRocks与Apache Iceberg:构建高效湖仓一体的实时分析平台

## 引言&#xff1a;数据湖的挑战与演进 在数据驱动的时代&#xff0c;企业数据湖需要同时满足海量存储、高性能查询、多引擎协作和实时更新等复杂需求。传统基于 Hive 的数据湖方案面临元数据管理低效、缺乏 ACID 事务支持、查询性能瓶颈等问题。在此背景下&#xff0c;**Sta…

Kafka 单机部署启动教程(适用于 Spark + Hadoop 环境)

&#x1f9ed; Kafka 单机部署启动教程&#xff08;适用于 Spark Hadoop 环境&#xff09; &#x1f4e6; 一、Kafka 版本选择 推荐使用 Kafka 2.13-2.8.1&#xff08;Scala 2.13&#xff0c;稳定适配 Spark 3.1.2 和 Hadoop 3.1.1&#xff09; 下载地址&#xff08;Apache 官…

C语言数组初始化方法大全(附带实例)

在 C语言中&#xff0c;数组用于存储相同类型的多个元素。数组的初始化是一个重要的概念&#xff0c;它允许我们在声明数组的同时为其赋初值。 这篇文章&#xff0c;我将为大家详细介绍 C语言中初始化数组的多种方法&#xff0c;以及一些需要注意的细节。 数组初始化的基本语…

RAMSUN分享全新超值型MM32F0050系列MCU

凭借全国产化的供应链优势和可靠的国产高端工艺制程&#xff0c;灵动微再次推出全新超值型MM32F0050系列微控制器单元&#xff08;MCU&#xff09;&#xff0c;将超值型MCU推向新的高度。 MM32F0050系列MCU配备了72MHz的Arm Cortex-M0内核&#xff0c;提供64KB的Flash存储和8K…

CMS32M65xx/67xx系列CoreMark跑分测试

CMS32M65xx/67xx系列CoreMark跑分测试 1、参考资料准备 1.1、STM32官方跑分链接 1.2、官网链接 官方移植文档&#xff0c;如下所示&#xff0c;点击红框处-移植文档: A new whitepaper and video explain how to port CoreMark-Pro to bare-metal 1.3、测试软件git下载链接 …

LeetCode 139. 单词拆分(Word Break) - 动态规划深度解析

文章目录 问题描述动态规划解法解法核心思路完整代码实现关键代码解析1. 数据结构初始化2. 动态规划数组3. 核心循环逻辑4. 子串区间理解(关键)示例演算复杂度分析算法优化点总结本文详细解析LeetCode 139题"单词拆分"的动态规划解法,涵盖核心思路、代码实现、区间…

获客方式有哪些拓展方向?

品牌在面临增长瓶颈时&#xff0c;如何拓展获客方式会是一个首要考虑的问题。有些时候企业会将获客渠道想得很复杂&#xff0c;其实仔细数下来&#xff0c;我们可以拓展的方向仍旧是根据渠道来溯源&#xff0c;因此相对固定。 一、跟随流行趋势 在数字营销领域&#xff0c;紧跟…

bug:undefined is not iterable (cannot read property Symbol(Symbol.iterator))

1.如图 2.分析 关键报错提示&#xff1a; undefined is not iterable (cannot read property Symbol(Symbol.iterator)) 直译&#xff1a; undefined是不可迭代的&#xff08;不能读取属性Symbol(Symbol.iterator)&#xff09; 理解&#xff1a; 有一个值、不存在&#x…

【笔记】PyCharm 使用问题反馈与官方进展速览

#工作记录 https://youtrack.jetbrains.com/issue/IJPL-190308 【笔记】记一次PyCharm的问题反馈_the polyglot context is using an implementation th-CSDN博客 【笔记】与PyCharm官方沟通解决开发环境问题-CSDN博客 与 JetBrains 官方沟通记录&#xff08;PyCharm 相关问题…

VSCode 工作区配置文件通用模板(CMake + Ninja + MinGW/GCC 编译器 的 C++ 或 Qt 项目)

下面是一个通用模板&#xff0c;适用于大多数使用 VSCode CMake Ninja MinGW/GCC 编译器 的 C 或 Qt 项目。你可以将这个 .vscode 文件夹复制到你的项目根目录下&#xff0c;稍作路径调整即可使用。 &#x1f4c1; .vscode/ 目录结构&#xff08;通用模板&#xff09; .vs…

栈-20.有效的括号-力扣(LeetCode)

一、题目解析 对于这个字符串需要左右括号匹配&#xff0c;并且是以正确的顺序 二、算法原理 解法1.图栈 解法2.用else if代替图栈 正常做法&#xff1a;对于三种左括号直接进栈((,[,{进栈)&#xff0c;然后判断与下一个括号是否匹配&#xff0c;匹配则出栈&#xff0c;不匹…

将音频数据累积到缓冲区,达到阈值时触发处理

实现了音频处理中的 AEC&#xff08;声学回声消除&#xff09;和 AES&#xff08;音频增强&#xff09;功能&#xff0c;其核心功能是&#xff1a; 数据缓冲管理&#xff1a;将输入的麦克风和扬声器音频数据块累积到缓冲区中块处理机制&#xff1a;当缓冲区填满预设大小&#…

fastadmin+workman环境搭建

一、出现错误 从git拉取到本地在配置网址登录后出现 unserialize(): Error at offset 0 of 17039 bytes 参考&#xff1a;https://blog.csdn.net/yqwwj001/article/details/88688675 找到 \thinkphp\library\think\cache\driver\Flie.php 中的 $content substr($content, …

若依+vue2实现模拟登录

1、背景 第三方通过链接访问若依项目&#xff0c;该链接通过携带唯一标识符&#xff1a;phone&#xff08;手机号&#xff09;&#xff0c;项目通过手机号查询本项目数据库人员信息实现模拟登录。 2、实现 2.1. 前端实现 2.1.1 创建专用模拟登录页面PhoneLogin.vue <te…

【2025】使用docker compose一键部署项目到服务器(4)

目录&#x1f4bb; 前言一、部署准备二、本地idea配置docker和docker compose执行器三、编写docker-compose.yml文件四、执行启动 前言 该篇文章主要是使用idea通过docker-compose.yml构建容器集合并且进行统一管理更新 该专栏主要为介绍通过docker compose实现容器编排部署 &…

Linux Windows之wsl安装使用简介

参考资料 如何使用 WSL 在 Windows 上安装 Linuxwindows11 安装WSL2全流程旧版 WSL 的手动安装步骤 目录 一. 前期准备1.1 确认windows的版本1.2 开启Linux子系统的支持1.2.1 图形化方式1.2.2 命令行方式 1.3 安装wsl软件1.4 安装Linux分发版 二. 基本配置2.1 Windows Termina…

matlab模糊控制实现路径规划

路径规划是机器人和自动驾驶系统中的重要问题之一&#xff0c;它涉及确定如何在给定环境中找到最优路径以达到特定目标。模糊控制是一种有效的控制方法&#xff0c;可以应用于路径规划问题。 路径规划算法的目标是在避免障碍物的情况下&#xff0c;找到机器人或车辆从起点到终…

OpenHarmony 5.0横竖屏界面适配

目录 一.背景 二.修改位置 三.参考文档 一.背景 由于需要一套代码适配横屏和竖屏设备,所以有些数值的大小可能在竖屏上面适配,在横屏上面不那么适配了,所以需要横屏特殊的数值大小(例如:宽高) 二.修改位置 在resources资源文件中新建横屏适配的文件夹,然后新建自己需…

AlphaFold3服务器安装与使用(非docker)(1)

1. 服务器显卡驱动准备 这部分我会详细记录一下我踩过的坑及怎样拯救的&#xff0c;原谅啰嗦啦 ^_^ 1.1 服务器旧配置 1.1.1 nvidia-smi [xxxxxxlocalhost ~]# nvidia-smi Thu May 29 20:54:00 2025 -------------------------------------------------------------…

Java异步编程难题拆解技术

目录 ​编辑 异步编程的核心概念 Java异步编程的主要实现方式 异步编程的常见难题 解决异步编程难题的策略 性能优化与调试技巧 实际案例分析 未来发展趋势 异步编程的核心概念 同步与异步的区别阻塞与非阻塞的差异Java异步编程的常见场景&#xff08;如网络请求、文件…