leecode-灌溉花园-贪心算法and动态规划

题目

思路1

将花园的灌溉点看作区间,建立一个数组存储这些区间,即数组下标表示左区间,数组存储右区间。

贪心算法,last记录在当前区间中,再选择1个区间未来能到达的最远距离,cur记录当前选择了的区间们的右边距。

当i到达cur的时候,就需要增加选择的区间了。

如果增加了区间,都还停留原地,即走不动了,那就是无法到达终点。即i==last,已经到达最远点。

cpp 复制代码
class Solution:
    def minTaps(self, n: int, ranges: List[int]) -> int:
        right_most = list(range(n+1))
        for i,r in enumerate(ranges):
            #记录每个区间的左右下标
            start = max(0, i - r)
            end = min(n, i + r)
            #将区间的左下标作为i,保存右下标(并合并能被包含的区间)
            right_most[start] = max(right_most[start], end)
        
        last = ans = cur = 0
        for i in range(n):
            last = max(last, right_most[i])#记录能覆盖的最大距离
            if i == cur:
                cur = last 
                ans += 1
            if i == last:
                return -1
        return ans

思路2

动态规划。

先计算出区间。

cpp 复制代码
class Solution:
    def minTaps(self, n: int, ranges: List[int]) -> int:
        #使用dp[i]表示覆盖区间[0,i]所需要的最少区间数目
        #新加入的区间是[startj,endj] 状态转移:dp[k] = min(dp[k], dp[startj]+1)
        intervals = []
        for i,r in enumerate(ranges):
            start = max(0, i-r)
            end = min(n, i+r)  #这个题有个陷阱,虽然花园长n,但是实际上是有n+1个点,因此这个是n
            intervals.append((start, end))
        intervals.sort()

        dp = [inf] * (n+1) #长度为n的花园,有n+1个区间,这里
        dp[0] = 0 #表示从位置0到位置0需要的喷头为0 ,因为还没浇水区间
        for start, end in intervals:
            if dp[start] == inf:
                return -1
            for j in range(start, end+1):
                dp[j] = min(dp[j], dp[start]+1)
        return dp[n]

           
相关推荐
kyle~2 小时前
C++--- dlsym 调用封装好的算法动态库的核心工具 <dlfcn.h>
开发语言·c++·算法
似水এ᭄往昔2 小时前
【初阶数据结构】--排序算法
数据结构·算法·排序算法
2301_781143562 小时前
C语言笔记(四)
c语言·笔记·算法
算法-大模型备案 多米2 小时前
算法备案算法安全自评估报告模板(精简完善版)
大数据·网络·人工智能·算法·文心一言
Frostnova丶2 小时前
LeetCode 238 & 2906.构造乘积数组与乘积矩阵
算法·leetcode·矩阵
张槊哲2 小时前
拆解大语言模型(LLM)的底层推演、架构演进与工业落地
算法
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章41-模板匹配
图像处理·人工智能·opencv·算法·计算机视觉
进击的小头2 小时前
第16篇:系统的稳定裕度分析
python·算法
黎阳之光3 小时前
AI数智筑防线 绿色科技启新篇,如何用硬核技术赋能生态安全双升级
人工智能·科技·算法·安全·数字孪生