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

做亚马逊有哪些网站可以清货智慧软文发稿平台

做亚马逊有哪些网站可以清货,智慧软文发稿平台,乐云seo网站建设公司,久久建筑资料网半月一去,望舒一轮,明天开始攻坚哈德题了 前言:非常经典的一道笔试题,看了保证血赚(今天银泰星笔试第四题就是这个) 题型:dp、模拟、双指针…… 链接:42. 接雨水 - 力扣&#xff…

半月一去,望舒一轮,明天开始攻坚哈德题了

前言:非常经典的一道笔试题,看了保证血赚(今天银泰星笔试第四题就是这个)

题型:dp、模拟、双指针……

链接:42. 接雨水 - 力扣(LeetCode)

来源:LeetCode

方法好多,这里用的“F大佬”的双指针思路

题目描述

本题为Hard题,建议配合样例&题解食用

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

题目样例

示例 1:

蓝色方块为雨水“个数”

输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
输出:6
解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 

示例 2:

输入:height = [4,2,0,3,2,5]
输出:9

提示:

  • n == height.length
  • 1 <= n <= 2 * 104
  • 0 <= height[i] <= 105

题目思路

初见这道题是银泰星的笔试第四道,道理明白,但是不知道怎么实现

这时候一股神秘的“东方力量”:dp,dp呀~

OK,那笔者就写一下自己用DP的做法(二周目,一周目是BE//(ㄒoㄒ)/~~)

能接到雨水,归根到底是保证两边的柱子高,中间柱子矮,那就可以存水。

这边可以把这种结构想象成【木桶】——那么影响木桶盛水的因素就是木桶的短板。虽然很抽象,但可以把相邻柱子的边看作是【木桶的板】,那么这个【木桶】能盛水的量,就是min(左板,右板)- height[i] 。

一个木桶是这样的,如果不断地扩大木桶的个数,那就相当于DP中的 将子问题放大了。

                ​​​​​​​        ​​​​​​​        ​​​​​​​        

当然断不可【无脑放大】——即只看相邻的柱子的高度。这部分,要想求得水的高度,说明【相邻最大的边】这个条件是不行的。这时候不难发现,应该是【右/左边最大的边】。这时候带入样例就合理多了。

那么获得【右/左边最长的边】,即获得两个方向最高柱子的高度,就是本题DP的破局点。
以求【往左走,经历过最高的柱子高度】为例,dpL[i] 表示 i 这个索引左边中,最高的柱子的高度。
可以dpL[i]会经历两个状态:①如果dpL[i-1] 比height[i]大,那k继续往左走,因为他之前的柱子中就有比height[k]高的 ② 如果dpL[k-1]要小的话,那就乖乖把dpL[i] 更新为height[i] 。

那么递归式就是: dp[i] = max(dp[i-1] , height[i])

因为木桶有两边的缘故,自然要求相反走向的【最高的柱子高度】

C++代码

dp,用了两个数组

class Solution {
public://银泰星笔试int trap(vector<int>& height) {int len = height.size();if(len <3)return 0;// 要确定动态申请数组的元素的个数,要不会野指针vector<int> dp_left(len);//从左边开始走vector<int> dp_right(len);//从右边开始走dp_left[0] = height[0];dp_right[len-1] = height[len-1];for(int i=1;i<len;i++){dp_left[i] = max(dp_left[i-1],height[i]);}for(int i=len-2;i>=0;i--){dp_right[i] = max(dp_right[i+1],height[i]);}int ans = 0;for(int i=0;i<len;i++){int temp = min(dp_left[i],dp_right[i]) - height[i];if(temp > 0)ans += temp;}return ans;}
};

结算页面 

dp

http://www.hkea.cn/news/89220/

相关文章:

  • 怎么用dw做静态网站b站好看的纪录片免费
  • 济南网站建设那家好网站制作公司有哪些
  • 域名和网站名不一样营销公司
  • discuz做电影网站免费网站seo
  • 惠民建设局网站明年2024年有疫情吗
  • 卫龙的网站是谁做的今日的新闻
  • 厚街找人做网站动态网站设计
  • 永春县住房和城乡规划建设局网站太原seo排名优化软件
  • 怎么上网站后台爱站小工具计算器
  • 网页编辑岗位职责seo上海优化
  • 网站做二维码吗做网站的外包公司
  • 郑州市中原区疫情最新消息上海网站营销seo方案
  • 狂人站群系统中国最权威的网站排名
  • 简单网站开发实例网站运营工作的基本内容
  • 飞机免费代理ip爱站网seo综合查询工具
  • 河南焦作有做网站开发的公司吗巩义网络推广公司
  • 邓州做网站网络广告有哪些形式
  • 爬闪数媒 网站建设网站建站流程
  • 网站建设广州白云百度统计app下载
  • 惠州短视频seoseowhy论坛
  • 肇庆网站快速排名优化温州seo排名公司
  • 北京疫情死亡人数最新消息王通seo赚钱培训
  • 北京做网站的外包公司营销策划方案案例范文
  • 专业做酒店网站关键词优化排名软件流量词
  • 做网站推广代理上海网络推广服务
  • wordpress可以做大吗搜索引擎优化的英语简称
  • 民治专业做网站公司中国企业500强排行榜
  • 潍坊 公司 网站seo点击排名器
  • 网站可以做赌博广告建站宝盒
  • 运城市做网站英文seo外链