题目
有M*N的节点矩阵,每个节点可以向8个方向(上、下、左、右及四个斜线方向)转发数据包,每个节点转发时会消耗固定时延,
连续两个相同时延可以减少一个时延值(即当有K个相同时延的节点连续转发时可以减少K- 1个时延值),
求左上角(0,0)开始转发数据包到右下角(M-1,N- 1)并转发出的最短时延。
输入描述
第一行两个数字,M、N,接下来有M行,每行有N个数据,表示M* N的矩阵。
输出描述
最短时延值。
示例1 输入输出示例仅供调试,后台判题数据一般不包含示例
3 3
0 2 2
1 2 1
2 2 1输出
3
示例2 输入输出示例仅供调试,后台判题数据一般不包含示例
3 3
2 2 2
2 2 2
2 2 2输出:
4
思路
1:关于图相关问题的解法,不是BFS 就是DFS,这里参考了大神 BFS 封装好的方法。思路是从一个顶点V0V0开始,辐射状地优先遍历其周围较广的区域。
2:广度优先搜索BFS(Breadth First Search)也称为宽度优先搜索,它是一种先生成的结点先扩
该博客介绍了如何使用Java解决华为OD机试中的一道题目——最小传输时延II。问题涉及到一个M*N的节点矩阵,每个节点可以向8个方向转发数据包,通过优化连续相同时延的节点来减少总时延。博客作者使用了广度优先搜索(BFS)算法来寻找从左上角到右下角的最短时延路径,并提供了思路和输入输出示例。
订阅专栏 解锁全文
690

被折叠的 条评论
为什么被折叠?



