电脑病毒感染【华为OD机试JAVA&Python&C++&JS题解】

149 篇文章 312 订阅 ¥9.90 ¥99.00

一. 题目-电脑病毒感染

一个局域网内有很多台电脑,分别标注为0 - N-1的数字。相连接的电脑距离不一样,所以感染时间不一样,感染时间用t表示。
其中网络内一个电脑被病毒感染,其感染网络内所有的电脑需要最少需要多长时间。如果最后有电脑不会感染,则返回-1
给定一个数组times表示一个电脑把相邻电脑感染所用的时间。
如图:path[i]= {i,j, t} 表示电脑i->j 电脑i上的病毒感染j,需要时间t。

输入描述:

4
3
2 1 1
2 3 1
3 4 1
2

输出描述:

2

补充说明:

第一个参数:局域网内电脑个数N 1<=N<=200;
第二个参数:总共多少条网络连接
第三个 1 2 1 表示1->2时间为1
第七行:表示病毒最开始所在的电脑号1

收起

示例1

输入:

4
3
2 1 1
2 3 1
3 4 1
2
输出:

2

二.解题思路

这个问题可以通过使用广度优先搜索(BFS)算法来解决。以下是解题思路:

  1. 首先,建立一个字典或者列表,用于表示网络连接关系。字典的键是电脑的编号,对应的值是一个列表,列表中包含与该电脑直接相连的电脑及感染所需的时间。

  2. 初始化一个数组 target,用于存储从起始感染电脑到每个电脑

  • 12
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值