当前位置: 首页 > news >正文

小米公司网络营销工具优化外包服务公司

小米公司网络营销工具,优化外包服务公司,黄石网站推广排名服务,网易邮箱企业版x轴上的花园范围为[0,n], 0~n这个n1个离散点上有水龙头,第 i 个水龙头能浇水的范围为[i-ranges[i], iranges[i]]. 求能浇整个花园的最小水龙头个数。 思路: 方法一: greedy 先把每个水龙头能浇的区间准备好, 用一个数组保存所有…

在这里插入图片描述

x轴上的花园范围为[0,n], 0~n这个n+1个离散点上有水龙头,第 i 个水龙头能浇水的范围为[i-ranges[i], i+ranges[i]].
求能浇整个花园的最小水龙头个数。

思路:

方法一
greedy

先把每个水龙头能浇的区间准备好,
用一个数组保存所有区间,数组下标为区间起点,数组内容为区间终点。

然后从左到右遍历这个数组,到这里就和55题Jump Game类似了。
用一个变量canReach表示到目前的水龙头为止能浇到的最远距离。preEnd表示前一个水龙头的区间终点。

如果当前位置 > preEnd,说明需要开一个新的水龙头,
但是如果这时canReach <= preEnd(前一水龙头处能浇到的最远距离也无法到达当前位置,后面有说明),说明无法到达,返回-1.
更新preEnd到canReach (canReach这时还没有更新,即preEnd更新到前一个水龙头为止的最远范围). 水龙头个数+1.
把canReach更新到和当前区间终点相比的较大值。

有一个特殊情况要注意下,就是Example2中ranges[i]=0的情况。
注意能浇水到整个花园说明不止是离散点i , i+1, …能浇到,i 到 i+1之间的连续点部分也必须在区间中。
而ranges[i] = 0 表示只能浇到离散点 i 本身。比如1,2点能浇到,但它们之间的1.1, 1.2, …都不在浇灌范围。
所以在处理区间时,canReach必须能到达当前点才算满足条件。

    public int minTaps(int n, int[] ranges) {int preEnd = 0;int canReach = 0;int[] startEnd = new int[n+1];int cnt = 0;for(int i = 0; i <= n; i++) {if(ranges[i] == 0) continue;int start = (i - ranges[i] < 0 ? 0 : i - ranges[i]);int end = (i + ranges[i] > n ? n : i + ranges[i]);startEnd[start] = end;}for(int i = 0; i <= n; i++) {if(i > preEnd) {if(canReach <= preEnd) return -1;cnt ++;preEnd = canReach;}if(startEnd[i] > canReach) canReach = startEnd[i];}//cnt是前一区间满足条件时在当前区间加的,最后一个区间没有下一区间去处理,所以要在最后处理一下//如果preEnd能到达最后位置,就不需要cnt+1,如果到不了,需要再cnt++,preEnd更新到canReachreturn cnt + (preEnd < n ? 1 : 0);}

方法二

DP
dp[i ] 表示浇到 i 位置所需的水龙头个数。
开始的时候,除了dp[0],其他全部初始化为无穷大。

还是像上面一样从左到右计算每个水龙头的浇水区间。
区间内每个点处所需的最少水龙头个数dp[ i ] = min(dp[i], dp[区间的起点]+1).
这是什么意义呢?
因为dp[0]=0, 当更新水龙头0的区间时,都会以dp[0]+1为准,把0处的水龙头能浇到的范围内,每个点处所需水龙头个数更新为1.
假设第一个区间为[0,2],更新如下
1 1 1 Inf Inf Inf
这时假如进入下一区间[2,4],那么在2的位置,仍然可以保持dp[2]=min(dp[2], dp[2]+1)=1.
到了位置3时,dp[3]=min(Inf,dp[2]+1)就变成需要2个水龙头。
同样的,如果前一范围覆盖不到后面的区间,就会出现min(inf, inf+1)的情况。
最后返回dp[n], 如果dp[n]为Inf, 说明无法浇到整个花园,返回-1.

    public int minTaps(int n, int[] ranges) {final int INF = 100000;int[] dp = new int[n+1];Arrays.fill(dp, INF);dp[0] = 0;for(int i = 0; i <= n; i++) {int start = (i-ranges[i] < 0 ? 0 : i-ranges[i]);int end = (i + ranges[i] > n ? n : i+ranges[i]);for(int j = start; j <= end; j++){dp[j] = Math.min(dp[j], dp[start]+1);}}return dp[n] == INF ? -1 : dp[n];}
http://www.yayakq.cn/news/47892/

相关文章:

  • 网站建设策划模板长沙网站排名优化费用
  • 高端品牌灯具威海seo
  • 云虚拟主机怎么做网站图片制作视频短片用什么软件好
  • 南京公司网站模板建站网站建设的价位
  • 青梦建站公众号制作开发公司
  • 学做网站需要掌握哪些知识免费推广引流平台有哪些
  • 提供做网站公司网上购物的设计与实现
  • 杭州精高端网站建设中国五码一级做爰网站
  • 静安集团网站建设知名的集团门户网站建设费用
  • 科技公司网站建设方案书模板wordpress+导入+媒体
  • 网站导航你一定会回来感谢我的免费无代码开发平台排行榜
  • 中山网站建设排名网站平台推广有哪些
  • js网站统计代码维护网站费用
  • 户网站开发的小公司删除wordpress缓存文件
  • 怎么建设咨询网站陕西网站建设平台
  • 网站建设策略阿里巴巴建设网站还不如搬砖
  • 海淘网站是谁做的上海网络营销有限公司
  • 网站织梦程序改成wordpress企业网站推广技巧和方法
  • 济南专门做公司网站的公司博客网站开发报告
  • 网站更改logo手机网站内容模块
  • 云南公司建网站多少钱区块链开发用什么语言
  • 天津市建设行业联合会网站公司做网站注意事项
  • 诸暨北京网站制作公司有哪些某些网站网速慢
  • 搭建个人博客网站怎样建立网站有哪些流程
  • 谁给个网站啊急急急2021贵港市网站建设
  • 自适应网站优点缺点网站模板 小说
  • 商派商城网站建设公司wordpress添加用户页面
  • 杭州 城西 做网站做php网站用的软件
  • 企业sns网站需求网站备案文件吗
  • 网站建设规划设计书小学学校网站建设培训资料