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

校园网门户网站建设洛阳设计公司官网

校园网门户网站建设,洛阳设计公司官网,世界十大互联网公司排名,怎么做免费域名网站题目#xff1a; 链接#xff1a;LeetCode 42. 接雨水 难度#xff1a;困难 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图#xff0c;计算按此排列的柱子#xff0c;下雨之后能接多少雨水。 示例 1#xff1a; 输入#xff1a;height [0,1,0,2,1,0,1,3,2,1,2…题目 链接LeetCode 42. 接雨水 难度困难 给定 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.length1 n 2 * 1040 height[i] 105 方法一 动态规划 按列求每一列能存的雨水时应该求这一列左右最高的墙其中较矮的墙与这一列高度的差值0为当前列能存的雨水量。对于求左右最高的墙我们可以用动态规划的方法做 首先用两个数组max_left [i] 代表第 i 列左边最高的墙的高度max_right[i] 代表第 i 列右边最高的墙的高度。一定要注意下第 i 列左右边最高的墙是不包括自身的 对于 max_left我们其实可以这样求。 max_left [i] Max(max_left [i-1],height[i-1])。它前边的墙的左边的最高高度和它前边的墙的高度选一个较大的就是当前列左边最高的墙了。 对于 max_right我们可以这样求。 max_right[i] Max(max_right[i1],height[i1]) 。它后边的墙的右边的最高高度和它后边的墙的高度选一个较大的就是当前列右边最高的墙了。 得到了左右最高墙的结果我们再用前面提到的方法按列求雨水量即可。 代码一 class Solution { public:int trap(vectorint height) {int n height.size();int maxleft[n], maxright[n];maxleft[0] 0, maxright[n - 1] 0;for(int i 1; i n; i){maxleft[i] max(maxleft[i - 1], height[i - 1]);}for(int i n - 2; i 0; i--){maxright[i] max(maxright[i 1], height[i 1]);}int sum 0;for(int i 1; i n - 1; i){int num min(maxleft[i], maxright[i]) - height[i];if(num 0) sum num;}return sum;} };时间复杂度O(N)。 空间复杂度O(N)。 方法二 单调栈 除了计算并存储每个位置两边的最大高度以外也可以用单调栈计算能接的雨水总量。 维护一个单调栈单调栈存储的是下标满足从栈底到栈顶的下标对应的数组 height 中的元素递减。 从左到右遍历数组遍历到下标 iii 时如果栈内至少有两个元素记栈顶元素为 toptop 的下面一个元素是 left则一定有 height[left] ≥ height[top]。如果 height[i] height[top]则得到一个可以接雨水的区域该区域的宽度是 i−left−1高度是 min⁡(height[left], height[i]) − height[top]根据宽度和高度即可计算得到该区域能接的雨水量。 为了得到 left需要将 top 出栈。在对 top 计算能接的雨水量之后left 变成新的 top重复上述操作直到栈变为空或者栈顶下标对应的 height 中的元素大于或等于 height[i]。 在对下标 i 处计算能接的雨水量之后将 i 入栈继续遍历后面的下标计算能接的雨水量。遍历结束之后即可得到能接的雨水总量。 代码二 class Solution { public:int trap(vectorint height) {int n height.size();stackint s; // 单调栈int sum 0;for(int i 0; i n; i){while(!s.empty() height[i] height[s.top()]) {int bottom height[s.top()];s.pop();int left, left_i;if(s.empty()) {left 0;left_i 0;}else {left height[s.top()];left_i s.top();}int wallHeight min(left, height[i]);int num (wallHeight - bottom) * (i - left_i - 1);if(num 0) sum num;}s.emplace(i);}return sum;} };时间复杂度O(N)N是数组 height 长度每个元素只会入栈和出栈一次。 空间复杂度O(N)栈空间最多为N。
http://www.w-s-a.com/news/968784/

相关文章:

  • 以下属于网站的管理 更新 维护如何才能做好品牌网站建设
  • 国家工业和信息化部网站备案系统网站建设设计费用
  • 网站建设利弊宁波高端网站建设联系方式
  • 网站订票策划方案郑州代做网站
  • 免费的网站加速器注册公司邮箱
  • 千助网站建设网站整站程序
  • 自学建网站做网站优化访问网站出现目录
  • 济南网站建设是什么百度官网登录入口手机版
  • net快速建站西宁手机网站建设
  • 网站浏览器不兼容怎么办软件系统开发大概多少钱
  • 网站建设哪个公司最好shift wordpress
  • 公司网站建设功能介绍室内设计学习
  • 做网站策划容易遇到哪些问题沈阳公司网站制作
  • 做php网站都用框架吗网站备案当面核验拍摄照片
  • 泉州企业自助建站兰州最好的互联网公司
  • 监察部门网站建设方案网站seo技术教程
  • 个人网站制作源代码下载品牌建设部
  • 网站备案需要准备什么文创产品设计思路
  • 网站开发书籍推荐青岛城阳新闻最新消息
  • 秦皇岛网站建设服务聊城做网站的公司资讯
  • 30岁转行做网站设计丰涵网站建设
  • 山东省和住房建设厅网站首页开发商不按时交房可以退房吗
  • asp网站怎么做404页面跳转本地南通网站建设
  • 点击网站出现微信二维码的链接怎么做申请网站空间怎么做
  • 网站开发的论文题目广告设计排行榜
  • 网络营销网站 功能南京h5制作公司
  • 做网站的费用的会计分录合肥做网站推广哪家好
  • 电子商城网站开发怎么wordpress用的什么主题
  • 榆林电商网站建设网上做试卷的网站
  • 文山网站建设代理中公教育培训机构官网