3528.单位转换I
dp, https://leetcode.cn/problems/unit-conversion-i/
有 n 种单位,编号从 0 到 n - 1。给你一个二维整数数组 conversions,长度为 n - 1,其中 conversions[i] = [sourceUniti, targetUniti, conversionFactori] ,表示一个 sourceUniti 类型的单位等于 conversionFactori 个 targetUniti 类型的单位。
请你返回一个长度为 n 的数组 baseUnitConversion,其中 baseUnitConversion[i] 表示 一个 0 类型单位等于多少个 i 类型单位。由于结果可能很大,请返回每个 baseUnitConversion[i] 对 10^9 + 7 取模后的值。
示例 1:
输入: conversions = [[0,1,2],[1,2,3]]
输出: [1,2,6]
解释:
- 使用
conversions[0]:将一个 0 类型单位转换为 2 个 1 类型单位。 - 使用
conversions[0]和conversions[1]将一个 0 类型单位转换为 6 个 2 类型单位。

示例 2:
输入: conversions = [[0,1,2],[0,2,3],[1,3,4],[1,4,5],[2,5,2],[4,6,3],[5,7,4]]
输出: [1,2,3,8,10,6,30,24]
解释:
- 使用
conversions[0]将一个 0 类型单位转换为 2 个 1 类型单位。 - 使用
conversions[1]将一个 0 类型单位转换为 3 个 2 类型单位。 - 使用
conversions[0]和conversions[2]将一个 0 类型单位转换为 8 个 3 类型单位。 - 使用
conversions[0]和conversions[3]将一个 0 类型单位转换为 10 个 4 类型单位。 - 使用
conversions[1]和conversions[4]将一个 0 类型单位转换为 6 个 5 类型单位。 - 使用
conversions[0]、conversions[3]和conversions[5]将一个 0 类型单位转换为 30 个 6 类型单位。 - 使用
conversions[1]、conversions[4]和conversions[6]将一个 0 类型单位转换为 24 个 7 类型单位。
提示:
2 <= n <= 10^5conversions.length == n - 10 <= sourceUniti, targetUniti < n1 <= conversionFactori <= 10^9- 保证单位 0 可以通过 唯一 的转换路径(不需要反向转换)转换为任何其他单位。
python
from typing import List
from collections import deque
class Solution:
def baseUnitConversions(self, conversions: List[List[int]]) -> List[int]:
n = len(conversions)
#conversions.sort(key=lambda x: (x[0], x[1]))
dp = [0] * (n+1)
dp[0] = 1
MOD = 10**9 + 7
for i in range(n):
s, t, f = conversions[i]
if s == 0:
dp[t] = f
else:
dp[t] = (dp[s] * f) % MOD
return dp
if __name__ == "__main__":
sol = Solution()
print(sol.baseUnitConversions([[0, 1, 2], [1, 2, 3]]))
print(sol.baseUnitConversions([[0,1,2],[0,2,3],[1,3,4],[1,4,5],[2,5,2],[4,6,3],[5,7,4]]))
print(sol.baseUnitConversions([[0,3,4],[3,2,7],[2,1,12]])) # [1,336,28,4]