Leetcode2246. 相邻字符不同的最长路径

编程入门 行业动态 更新时间:2024-10-23 16:18:41

Leetcode2246. 相邻字符不同的最长<a href=https://www.elefans.com/category/jswz/34/1771438.html style=路径"/>

Leetcode2246. 相邻字符不同的最长路径

Every day a Leetcode

题目来源:2246. 相邻字符不同的最长路径

解法1:树形 DP

如果没有相邻节点的限制,那么本题求的就是树的直径上的点的个数,见于Leetcode543. 二叉树的直径。

考虑用树形 DP 求直径。

枚举子树 x 的所有子树 y,维护从 x 出发的最长路径 maxLen,那么可以更新答案为从 y 出发的最长路径加上 maxLen,再加上 1(边 x−>y),即合并从 x 出发的两条路径。递归结束时返回 maxLen。

对于本题的限制,我们可以在从子树 y 转移过来时,仅考虑从满足 s[y]≠s[x] 的子树 y 转移过来,所以对上述做法加个 if 判断就行了。

由于本题求的是点的个数,所以答案为最长路径的长度加 1。

代码:

/** @lc app=leetcode id=2246 lang=cpp** [2246] 相邻字符不同的最长路径*/// @lc code=start
class Solution
{
public:int longestPath(vector<int> &parent, string s){int n = parent.size();vector<vector<int>> g(n);for (int i = 1; i < n; ++i)g[parent[i]].push_back(i);int ans = 0;function<int(int)> dfs = [&](int x) -> int{int maxLen = 0;for (int &y : g[x]){int len = dfs(y) + 1;if (s[y] != s[x]){ans = max(ans, maxLen + len);maxLen = max(maxLen, len);}}return maxLen;};dfs(0); // 根节点是节点 0return ans + 1;}
};
// @lc code=end

结果:

复杂度分析:

时间复杂度:O(n),其中 n 是数组 parent 的长度。

空间复杂度:O(n),其中 n 是数组 parent 的长度。

更多推荐

Leetcode2246. 相邻字符不同的最长路径

本文发布于:2023-11-15 07:55:16,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1596271.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:路径   字符   最长

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!