Leetcode 1025 Solution
This article provides solution to leetcode question 1025 (minimum-cost-for-tickets).
Access this page by simply typing in "lcs 1025" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/minimum-cost-for-tickets
Solution
class Solution:
def dp(self, days, i, costs):
if i >= len(days):
return 0
if i in self.memo:
return self.memo[i]
opts = []
for cost, duration in zip(costs, [1, 7, 30]):
j = i
while j < len(days) and days[j] - days[i] < duration:
j += 1
opt = self.dp(days, j, costs) + cost
opts.append(opt)
self.memo[i] = min(opts)
return self.memo[i]
def mincostTickets(self, days, costs):
self.memo = collections.Counter()
return self.dp(days, 0, costs)