文章目录

  • 1. 题目
  • 2. 解题

1. 题目

给你一张 无向 图,图中有 n 个节点,节点编号从 0 到 n - 1 (都包括)。
同时给你一个下标从 0 开始的整数数组 values ,其中 values[i] 是第 i 个节点的 价值 。同时给你一个下标从 0 开始的二维整数数组 edges ,其中 edges[j] = [uj, vj, timej] 表示节点 uj 和 vj 之间有一条需要 timej 秒才能通过的无向边。最后,给你一个整数 maxTime 。

合法路径 指的是图中任意一条从节点 0 开始,最终回到节点 0 ,且花费的总时间 不超过 maxTime 秒的一条路径。
你可以访问一个节点任意次
一条合法路径的 价值 定义为路径中 不同节点 的价值 之和 (每个节点的价值 至多 算入价值总和中一次)。

请你返回一条合法路径的 最大 价值。

注意:每个节点 至多 有 四条 边与之相连。

示例 1:

输入:values = [0,32,10,43],
edges = [[0,1,10],[1,2,15],[0,3,10]], maxTime = 49
输出:75
解释:
一条可能的路径为:0 -> 1 -> 0 -> 3 -> 0 。
总花费时间为 10 + 10 + 10 + 10 = 40 <= 49 。
访问过的节点为 0 ,1 和 3 ,最大路径价值为 0 + 32 + 43 = 75 。

示例 2:

输入:values = [5,10,15,20],
edges = [[0,1,10],[1,2,10],[0,3,10]], maxTime = 30
输出:25
解释:
一条可能的路径为:0 -> 3 -> 0 。
总花费时间为 10 + 10 = 20 <= 30 。
访问过的节点为 0 和 3 ,最大路径价值为 5 + 20 = 25 。

示例 3:

输入:values = [1,2,3,4],
edges = [[0,1,10],[1,2,11],[2,3,12],[1,3,13]], maxTime = 50
输出:7
解释:
一条可能的路径为:0 -> 1 -> 3 -> 1 -> 0 。总花费时间为 10 + 13 + 13 + 10 = 46 <= 50 。
访问过的节点为 0 ,1 和 3 ,最大路径价值为 1 + 2 + 4 = 7 。

示例 4:

输入:values = [0,1,2],
edges = [[1,2,10]], maxTime = 10
输出:0
解释:
唯一一条路径为 0 。总花费时间为 0 。
唯一访问过的节点为 0 ,最大路径价值为 0 。提示:
n == values.length
1 <= n <= 1000
0 <= values[i] <= 10^8
0 <= edges.length <= 2000
edges[j].length == 3
0 <= uj < vj <= n - 1
10 <= timej, maxTime <= 100
[uj, vj] 所有节点对 互不相同 。
每个节点 至多有四条 边。
图可能不连通。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-path-quality-of-a-graph
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 看见条件 10 <= timej, maxTime <= 100,最多 dfs 10 层就完事了
  • 建图,暴力搜索就是了
class Solution {int maxVal = 0;
public:int maximalPathQuality(vector<int>& values, vector<vector<int>>& edges, int maxTime) {int n = values.size();vector<unordered_map<int,int>> g(n);vector<int> vis(n);for(auto& e : edges){ // 建图g[e[0]][e[1]] = e[2];g[e[1]][e[0]] = e[2];}vis[0] = 1; // 访问节点次数dfs(g, values, maxTime, vis, 0, 0, values[0]);return maxVal;}void dfs(vector<unordered_map<int,int>>& g, vector<int>& values, int maxTime, vector<int>& vis, int idx, int time, int val){if(time > maxTime) return; // 超时了if(idx==0 && val > maxVal){maxVal = val;}for(auto& nid_t : g[idx]){ //遍历相邻节点int nid = nid_t.first; // 相邻节点编号int t = nid_t.second; // 需要花费时间if(vis[nid] == 0) // 没有访问这个节点,可以获得价值{vis[nid]++;dfs(g, values, maxTime, vis, nid, time+t, val+values[nid]);vis[nid]--;}else // 访问过了,不能再获得价值{vis[nid]++;dfs(g, values, maxTime, vis, nid, time+t, val);vis[nid]--;}}}
};

404 ms 23.6 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

LeetCode 2065. 最大化一张图中的路径价值(DFS)相关推荐

  1. LeetCode 2065. 最大化一张图中的路径价值

    文章目录 一.题目 1.题目描述 2.基础框架 3.原题链接 二.解题报告 1.思路分析 2.时间复杂度 3.代码详解 三.本题小知识 四.加群须知 一.题目 1.题目描述   给你一张无向图,图中有 ...

  2. LeetCode 2065. Maximum Path Quality of a Graph(最大化一张图中的路径价值)

    问题描述 思路与代码 本体参考官方题解,通过深度优先搜索解决: LeetCode 2065 官方题解 注意两件事情: 当重复到达某一节点时,不能重复获取价值: 若起点为孤立点,直接返回. 代码如下: ...

  3. Leetcode 1559二维网格图中探测环 技巧DFS|剪枝

    二维网格图中探测环 给你一个二维字符网格数组 grid ,大小为 m x n ,你需要检查 grid 中是否存在 相同值 形成的环. 一个环是一条开始和结束于同一个格子的长度 大于等于 4 的路径.对 ...

  4. R语言可视化包ggplot2在一张图中画出两条线实战

    R语言可视化包ggplot2在一张图中画出两条线实战 目录 R语言可视化包ggplot2在一张图中画出两条线实战

  5. python 子图_python 实现在一张图中绘制一个小的子图方法

    有时候为了直观展现图的信息,可以在大图中添加小子图的方式进行数据分析,如下图所示: 具体的代码如下:该图连接了数据库,当然重要的不是数据展示,而是添加子图的方法. import matplotlib. ...

  6. python画50个图-python 实现在一张图中绘制一个小的子图方法

    有时候为了直观展现图的信息,可以在大图中添加小子图的方式进行数据分析,如下图所示: 具体的代码如下:该图连接了数据库,当然重要的不是数据展示,而是添加子图的方法. import matplotlib. ...

  7. python画简便的图-python 实现在一张图中绘制一个小的子图方法

    有时候为了直观展现图的信息,可以在大图中添加小子图的方式进行数据分析,如下图所示: 具体的代码如下:该图连接了数据库,当然重要的不是数据展示,而是添加子图的方法. import matplotlib. ...

  8. MATLAB中利用cftool导出代码实现一张图中拟合多条平滑曲线

    MATLAB中自带的cftool拟合工具箱不能将多条曲线同时画在同一副图中,而常规的plot()函数又不能拟合平滑直线,接下来总结一种可以利用cftool导出的代码,在一张图中拟合多条平滑曲线. 首先 ...

  9. R语言ggplot2可视化、在一张图中画出两条曲线(two lines in same ggplot2 graph)、使用pdf函数将ggplot2可视化图像保存到指定目录的pdf格式文件中

    R语言ggplot2可视化.在一张图中画出两条曲线(two lines in same ggplot2 graph).使用pdf函数将ggplot2可视化图像保存到指定目录的pdf格式文件中 目录

最新文章

  1. C语言判断数组中是否存在该数
  2. python分片操作_【python原理解析】python中分片的实现原理及使用技巧
  3. oracle取本月最后一天是星期几_Oracle取得本月、本年第一天和最后一天
  4. RocketMQ事务消息的三种状态
  5. python123 helloworld_python入门
  6. ANSYS——模态提取方法简介
  7. python listbox排序_python – 从tkinter.Listbox中提取项目列表
  8. Spring MVC:带有CNVR卷的REST应用程序。 2
  9. 04.卷积神经网络 W3.目标检测(作业:自动驾驶 - 汽车检测)
  10. 快速建站-html基础-0223
  11. 大数据学习笔记31:Java程序访问高可用Hadoop集群
  12. caffe 利用python绘制loss曲线以及accuracy曲线
  13. sync in demos
  14. Xcode如何显示代码行数
  15. 历史上的重大软件BUG启示录 第6篇---蠕虫“冲击波”
  16. 小米蓝牙音响驱动_小米极蜂智能对讲机体验:联网对讲,还能当“老头乐”蓝牙音响...
  17. tomcat 如何进行优化?优化方案有哪些?
  18. 那智机器人工具坐标设置方法
  19. php环境下,两种汇率接口,已经测试通过
  20. 揭秘;抖音美妆账号如何做?如何玩转抖音美妆类运营:国仁楠哥

热门文章

  1. java线程interrupt用法_Java线程中interrupt那点事 | 学步园
  2. 《操作系统》OS学习(三):系统调用
  3. 单例设计模式-懒汉式(线程不安全)
  4. linux proc文件 write的原子性,linux - Linux中writev()系统调用的原子性 - 堆栈内存溢出...
  5. api商品分享源码_SSM框架高并发和商品秒杀项目高并发秒杀API源码免费分享
  6. 物理机安装ESXI6.7提示No Network Adapters的解决方案
  7. less is more,so 只记 less
  8. oracle 12.2.0.1 搭建 active dataguard
  9. 一个关于Remoting的简单例子
  10. 聊透分布式系统一致性