Python | Leetcode Python题解之第399题除法求值

题目:

题解:

python 复制代码
class Solution:
    def calcEquation(self, equations: List[List[str]], values: List[float], queries: List[List[str]]) -> List[float]:
        # 构造图
        graph = defaultdict(list)
        for (u, v), value in zip(equations, values):
            graph[u].append((v, value))
            graph[v].append((u, 1 / value))

        def dfs(node, target, visited, acc_product):
            # 如果找到了目标节点,返回累积乘积
            if node == target:
                return acc_product
            # 标记当前节点为已访问
            visited.add(node)
            # 遍历当前节点的邻居
            for neighbor, value in graph[node]:
                if neighbor not in visited:
                    result = dfs(neighbor, target, visited, acc_product * value)
                    if result != -1:
                        return result
            return -1

        results = []
        for start, end in queries:
            if start in graph and end in graph:
                # 如果起点和终点都在图中,进行DFS
                results.append(dfs(start, end, set(), 1.0))
            else:
                # 否则,结果为-1
                results.append(-1.0)
        
        return results
相关推荐
大江东去浪淘尽千古风流人物1 分钟前
【Sensor】IMU传感器选型车轨级 VS 消费级
人工智能·python·算法·机器学习·机器人
wangwangmoon_light29 分钟前
1.2 LeetCode总结(线性表)_双指针
算法·leetcode·职场和发展
码农小韩1 小时前
AIAgent应用开发——DeepSeek分析(一)
人工智能·python·深度学习·agent·强化学习
学Linux的语莫1 小时前
skills的使用
java·数据库·python
Bear on Toilet2 小时前
BFS_FloodFill_46 . 腐烂的橘子问题
数据结构·c++·算法·leetcode·宽度优先
样例过了就是过了2 小时前
LeetCode热题100 找到字符串中所有字母异位词
算法·leetcode
像风一样的男人@2 小时前
python --打包pyd或so文件
开发语言·python
MediaTea3 小时前
Python:生成器对象的扩展接口
开发语言·网络·python
滴滴答滴答答3 小时前
LeetCode Hot100 之 17 合并区间
算法·leetcode·职场和发展
Katecat996633 小时前
基于FCOS-HRNetV2P的高空作业安全装备检测与违规行为识别系统
python