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

天津中小企业建设网站电子商务网站建设 教案

天津中小企业建设网站,电子商务网站建设 教案,做网站哪家专业,泰州哪家做网站建设比较好题目描述 现在有n个容器服务,服务的启动可能有一定的依赖性(有些服务启动没有依赖),其次,服务自身启动加载会消耗一些时间。 给你一个 n n n \times n nn的二维矩阵useTime,其中useTime[i][i]10表示服务…

题目描述

现在有n个容器服务,服务的启动可能有一定的依赖性(有些服务启动没有依赖),其次,服务自身启动加载会消耗一些时间。

给你一个 n × n n \times n n×n的二维矩阵useTime,其中useTime[i][i]=10表示服务i自身启动加载需要消耗10s,useTime[i][j]=1表示服务i启动依赖服务j启动完成,useTime[i][k]=0表示服务i启动不依赖服务k。其中o <= i, j, k < n。服务之间没有循环依赖(不会出现环),若想对任意一个服务i进行集成测试(服务i自身也需要加载),求最少需要等待多少时间。

输入描述

第一行输入服务总量n,之后的n行表示服务启动的依赖关系以及自身启动加载耗时,最后输入k表示计算需要等待多少时间后,可以对服务k进行集成测试,其中1 <= k <= n, 1 <= n <= 100

输出描述

最少需要等待多少时间(单位:秒)后,可以对服务k进行集成测试。

示例描述

示例一

输入:

3
5 0 0
1 5 0
0 1 5
3

输出:

15

说明:
服务3启动依赖服务2,服务2启动依赖服务1,由于服务1、2、3自身加载都需要消耗5s,所以5+5+5=15s,需要等待15s后可以对服务3进行集成测试。

示例二

输入:

3
5 0 0
1 10 1
1 0 11
2

输出:

26

说明:
服务2启动依赖服务1和服务3,服务3启动需要依赖服务1,服务1、2、3自身加载需要消耗5s、10s、11s,所以5+10+11=26s,需要等待26s后可以对服务2进行集成测试。

示例三

输入:

4
2 0 0 0
0 3 0 0
1 1 4 0
1 1 1 5
4

输出:

12

说明:
服务3启动依赖服务1和服务2,服务4启动需要依赖服务1、2、3,服务1、2、3、4自身加载需要消耗2s、3s、4s、5s,所以3+4+5=12s(因为服务1和服务2可以同时启动),需要等待12s后可以对服务4进行集成测试。

示例四

输入:

5
1 0 0 0 0
0 2 0 0 0
1 1 3 0 0
1 1 0 4 0
0 0 1 1 5
5

输出:

11

说明:
服务3启动依赖服务1和服务2,服务4启动需要依赖服务1和服务2,服务5启动需要依赖服务3和服务4,服务1、2、3、4、5自身加载需要消耗1s、2s、3s、4s、5s,所以2+4+5=11s(因为服务1和服务2可以同时启动,服务3和服务4可以同时启动),需要等待11s后可以对服务5进行集成测试。

解题思路

  1. 本题使用深度优先遍历DFS进行解题;
  2. 调用深度优先遍历,返回总耗时
  3. 深度优先遍历:
    1. 确认递归函数的参数:参数包括服务k、服务耗时矩阵arr
    2. 终止条件:当查找不到启动依赖服务终止,返回耗时,并加上服务自身耗时。
    3. 处理:遍历服务,得到服务k启动依赖的服务。
    4. 递归遍历,计算下一层依赖服务的耗时,得到总最大服务耗时时间。
  4. 返回服务总耗时时间。

解题代码

def dfs(arr, k):max_time = 0# 遍历服务for i in range(len(arr)):# 得到服务k启动依赖的服务if arr[k][i] != 0 and i != k:# 计算启动依赖服务的最大耗时,并记录到总耗时中max_time = max(max_time, dfs(arr, i))return max_time + arr[k][k]def solve_method(arr, k):total_time = dfs(arr, k - 1)return total_timeif __name__ == '__main__':k = 3useTime = [[5, 0, 0],[1, 5, 0],[0, 1, 5]]assert solve_method(useTime, k) == 15k = 2useTime = [[5, 0, 0],[1, 10, 1],[1, 0, 11]]assert solve_method(useTime, k) == 26k = 4useTime = [[2, 0, 0, 0],[0, 3, 0, 0],[1, 1, 4, 0],[1, 1, 1, 5],]assert solve_method(useTime, k) == 12k = 5useTime = [[1, 0, 0, 0, 0],[0, 2, 0, 0, 0],[1, 1, 3, 0, 0],[1, 1, 0, 4, 0],[0, 0, 1, 1, 5]]assert solve_method(useTime, k) == 11

在这里插入图片描述


文章转载自:

http://6TCGknAv.fqfkx.cn
http://JECiQ5l5.fqfkx.cn
http://cDXzxRA2.fqfkx.cn
http://3P6UccfA.fqfkx.cn
http://TuQ6lI82.fqfkx.cn
http://Hn22Au8A.fqfkx.cn
http://mrAVhMQu.fqfkx.cn
http://QiLeVuBi.fqfkx.cn
http://ZPXeReU5.fqfkx.cn
http://irZTfPL1.fqfkx.cn
http://D22aHTJw.fqfkx.cn
http://6VpU1s1K.fqfkx.cn
http://Zk3lx35P.fqfkx.cn
http://XdUcVYIU.fqfkx.cn
http://IuxjLcSD.fqfkx.cn
http://xLbbsoAB.fqfkx.cn
http://v3HXKIa5.fqfkx.cn
http://pRxT1Zce.fqfkx.cn
http://qhcten4p.fqfkx.cn
http://1JZOgZWV.fqfkx.cn
http://u6ODb76C.fqfkx.cn
http://VjvsxSjR.fqfkx.cn
http://cTqq0WG3.fqfkx.cn
http://v8DcBUKb.fqfkx.cn
http://fk2zVKy8.fqfkx.cn
http://34ECcK6I.fqfkx.cn
http://WA2RIXDl.fqfkx.cn
http://hsbuA9YV.fqfkx.cn
http://nYDaSIBf.fqfkx.cn
http://NHWwTdGW.fqfkx.cn
http://www.dtcms.com/wzjs/721779.html

相关文章:

  • 创业平台网站谷歌搜索引擎
  • 可以发布外链的网站安徽人防工程建设网站
  • 大学帮学校做网站2345网址导航站
  • 网站建设 有哪些费用网站怎么适配移动端
  • 网站建设首页突出什么inovation wordpress
  • 网站流量如何盈利方案 网站建设
  • 网站开发教学大纲免费logo头像在线制作
  • 网站运营内容方案在线设计平台的缺点
  • 做网站用哪种代码比较好推广如何设计软件界面
  • 松滋做网站做网站要付哪些钱
  • 松江建设网站公司陶艺品网站模板
  • 网站建设与实现的要求与务怎么申请微信公众号
  • 专业企业网站开发联系电话公司网站必须做可信认证吗
  • 购物网站开店免费长沙网站seo推广公司
  • 男女做暖暖的试看网站遵义网
  • 深圳企业网站开发费用莱芜一中贴吧
  • discuz网站模板织梦协会网站模板
  • 百度seo整站优化公司修改wordpress 表格
  • 网站成品免费下载网页配色的技巧是什么
  • 简述网站制作流程株洲sem优化哪家好
  • 企业需求做网站在哪儿交易免费推广平台哪个好
  • 门户网站的营销方式珠海图远建设公司网站
  • 网站建设验收内容免费外链生成器
  • 网络推广网站电话详情页的五个基本模块
  • 网站建设求职要求网站建设营销排名方案
  • 怎么建设一个淘宝客网站界面设计效果图排版
  • 文联网站建设方案网页设计需要掌握哪些技能
  • iis7 asp网站 503wordpress+屏蔽ip插件
  • 张家界做网站找哪家好抖音引流推广免费软件app
  • 网站的系统建设方式有哪些方面烟台企业网站建设