接雨水12 · Trapping Rain Water12
[抄题]:
Given n non-negative integers representing an elevation map where the width of each bar is 1, compute how much water it is able to trap after raining.

[暴力解法]:
时间分析:
空间分析:
[思维问题]:
- 灌水的多少基本上由左右边界中较矮的一块木板开始,由相邻是否有较高的木板决定。第一次学灌水,算了
[一句话思路]:
[输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入):
[画图]:
灌水的多少基本上由左右边界的木板决定。


[一刷]:
[二刷]:
[三刷]:
[四刷]:
[五刷]:
[五分钟肉眼debug的结果]:
[总结]:
[复杂度]:Time complexity: O(n) Space complexity: O(n)
[英文数据结构或算法,为什么不用别的数据结构或算法]:
[关键模板化代码]:
while (left < right) {
if (heights[left] < heights[right]) {
//start from left
left++;
if (left_max > heights[left]) {
result += (left_max - heights[left]);
}else {
left_max = heights[left];
}
}else {
//start from right
right--;
if (right_max > heights[right]) {
result += (right_max - heights[right]);
}else {
right_max = heights[right];
}
}
}
while (left < right)的基础上才能循环
[其他解法]:
[Follow Up]:
[LC给出的题目变变变]:
装最多水的容器 · Container With Most Water 2指针
[代码风格] :
public class Solution {
/**
* @param heights: a list of integers
* @return: a integer
*/
public int trapRainWater(int[] heights) {
int result = 0;
//corner case
if (heights == null || heights.length == 0) {
return 0;
}
int left = 0;
int right = heights.length - 1;
int left_max = heights[left];
int right_max = heights[right];
while (left < right) {
if (heights[left] < heights[right]) {
//start from left
left++;
if (left_max > heights[left]) {
result += (left_max - heights[left]);
}else {
left_max = heights[left];
}
}else {
//start from right
right--;
if (right_max > heights[right]) {
result += (right_max - heights[right]);
}else {
right_max = heights[right];
}
}
}
return result;
}
}
[抄题]:
Given n x m non-negative integers representing an elevation map 2d where the area of each cell is 1 x 1, compute how much water it is able to trap after raining.

Given 5*4 matrix
[12,13,0,12]
[13,4,13,12]
[13,8,10,12]
[12,13,12,12]
[13,13,13,13]
return 14.
[暴力解法]:
时间分析:
空间分析:
[思维问题]:
- 以为从四个角当作外围,朝中间过渡。应该把四堵墙当作外围,要能把中间都包起来才能做外围。
- 怎么想不到利用堆,要分析数据特点再选数据结构 而不是一个个套用数据结构:每次都是从q的顶点(最矮的点)从低往高注水,故用heap.
- q中放的是能向四周扩展的cell, 但是每次都是从q的顶点(最矮的点)从低往高注水。不是从高往低duang地一下往下倒,没想象出来。
[一句话思路]:
[输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入):
[画图]:
[一刷]:
- PQ的括号里要传新建的引用new CellComparator(),体现参数的多态
- q中没有cell并往里头放时,新建即可
- 队列已经创建出对象,则不用null。再判断对象是否为零,因此用isempty()
- 从0 开始,取m个数,最后一个应该是m - 1,老是稍微理解了然后又忘了
- java int[] 未初始化时默认值是,integer[]未初始化时默认值是null
- int[][] visit = new int[n][m]; 已经忘写好几次了
[二刷]:
[三刷]:
[四刷]:
[五刷]:
[五分钟肉眼debug的结果]:
[总结]:
灌水(扩展类)本质还是BFS,区区几个算法中的一种。要分析数据特点再选数据结构 而不是一个个套用数据结构
[复杂度]:Time complexity: O(m*n个元素*lg(m+n)每个元素在heap中取最小值) Space complexity: O(m*n个点保存在去重矩阵中)
[英文数据结构或算法,为什么不用别的数据结构或算法]:
- BFS,“扩展类”问题就应该想到,印象还不够深
- dp好用,可不要贪杯哦
- 重写@override是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变。重载(overloading) 是在一个类里面,方法名字相同,而参数不同。
[关键模板化代码]:
class CellComparator implements Comparator<Cell> {
public int compare(Cell a, Cell b) {
if (a.h > b.h) {
return 1;
}else if (a.h == b.h) {
return 0;
}else {
return -1;
}
}
}
自制CellComparator
[其他解法]:
[Follow Up]:
[LC给出的题目变变变]:
542. 01 Matrix 所有点,用dfs
279. Perfect Squares dp
529. Minesweeper 扫雷 DFS BFS无疑了
[代码风格] :
class Cell {
int x, y, h;
Cell (int xx, int yy, int hh) {
x = xx;
y = yy;
h = hh;
}
}
class CellComparator implements Comparator<Cell> {
public int compare(Cell a, Cell b) {
if (a.h > b.h) {
return 1;
}else if (a.h == b.h) {
return 0;
}else {
return -1;
}
}
}
public class Solution {
/**
* @param heights: a matrix of integers
* @return: an integer
*/
public int trapRainWater(int[][] heightMap) {
int result = 0;
int n = heightMap.length;
int m = heightMap[0].length;
int[][] visit = new int[n][m];
int[] dx = {0, 1, 0, -1};
int[] dy = {1, 0, -1, 0};
//corner case
if (heightMap == null || m == 0 || n == 0) {
return 0;
}
PriorityQueue<Cell> q = new PriorityQueue<>(new CellComparator());
//get 4 edges into q
for (int i = 0; i < n; i++) {
q.offer(new Cell(i, 0, heightMap[i][0]));
q.offer(new Cell(i, m - 1, heightMap[i][m - 1]));
visit[i][0] = 1;
visit[i][m - 1] = 1;
}
for (int j = 0; j < m; j++) {
q.offer(new Cell(0, j, heightMap[0][j]));
q.offer(new Cell(n - 1, j, heightMap[n - 1][j]));
visit[0][j] = 1;
visit[n - 1][j] = 1;
}
//bfs
while (!q.isEmpty()) {
Cell now = q.poll();
int cx = now.x;
int cy = now.y;
for (int i = 0; i < 4; i++) {
int nx = cx + dx[i];
int ny = cy + dy[i];
if (0 <= nx && nx < n && 0 <= ny && ny < m &&
visit[nx][ny] == 0) {
visit[nx][ny] = 1;
q.offer(new Cell(nx, ny, Math.max(now.h, heightMap[nx][ny])));
result += Math.max(0, now.h - heightMap[nx][ny]);
}
}
}
return result;
}
}
接雨水12 · Trapping Rain Water12的更多相关文章
- [Swift]LeetCode407. 接雨水 II | Trapping Rain Water II
Given an m x n matrix of positive integers representing the height of each unit cell in a 2D elevati ...
- LeetCode 42. 接雨水(Trapping Rain Water)
题目描述 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水. 上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况 ...
- LeetCode 笔记系列12 Trapping Rain Water [复杂的代码是错误的代码]
题目:Given n non-negative integers representing an elevation map where the width of each bar is 1, com ...
- [LeetCode] Trapping Rain Water 收集雨水
Given n non-negative integers representing an elevation map where the width of each bar is 1, comput ...
- [LeetCode] 42. Trapping Rain Water 收集雨水
Given n non-negative integers representing an elevation map where the width of each bar is 1, comput ...
- [LeetCode] 407. Trapping Rain Water II 收集雨水 II
Given an m x n matrix of positive integers representing the height of each unit cell in a 2D elevati ...
- [LintCode] Trapping Rain Water 收集雨水
Given n non-negative integers representing an elevation map where the width of each bar is 1, comput ...
- leetCode 42.Trapping Rain Water(凹槽的雨水) 解题思路和方法
Trapping Rain Water Given n non-negative integers representing an elevation map where the width of e ...
- [LeetCode] 接雨水,题 Trapping Rain Water
这题放上来是因为自己第一回见到这种题,觉得它好玩儿 =) Trapping Rain Water Given n non-negative integers representing an eleva ...
随机推荐
- 使用c++实现一个FTP客户端(一)
之前使用c++实现了一个FTP客户端,在这里做一些记录. 一.需要注意的几点 ①FTP是一种文件传输协议,基于TCP,所以客户端与服务器建立的连接是可靠.安全的,并且要经过三次握手的过程. ②FTP传 ...
- 在pixi中使用你的自定义着色器
通过几天的学习,对openGL.shader有了一个大致的了解. 回到学习的初衷吧,在基于pixi.js重构D3项目的时候,因为精灵层级的问题,我得按照一定的先后顺序将不同类别的精灵添加到场景中去. ...
- 如何在idea中使用Mybatis-generator插件快速生成代码
传送门 使用这个插件可以快速生成一些代码,包含 实体类/Mapper接口/*Mapper.xml文件 首先,我们需要搭建一个Maven的项目. 在pom.xml中添加代码 <plugins> ...
- 20165212实验三——敏捷开发与XP实践
20165212实验三 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 实验知识点总结 (一)敏捷开发与XP 软件工程:把系统的.有序的.可量化的方法应用到软件的开发.运营和维护上的过 ...
- flask第二十六篇——模板【控制语句】【2】
如果你也在学flask,就请加船长的公众号:自动化测试实战 我们先补充一下for循环的知识,我们之前说过,flask是由Jinja2+sqlAlchemy+werkzeug组成的,我们现在学的控制语句 ...
- ORA-01033: ORACLE initialization or shutdown in progress --手动删除表空间 DBF 后无法登陆问题
进入CMD,执行set ORACLE_SID=fbms,确保连接到正确的SID: 2.执行sqlplus "/as sysdba" SQL>shutdown immediat ...
- 开始SDK之旅-入门1基本环境搭建与测试
已验证这个可用. http://bbs.ccflow.org/showtopic-2560.aspx 集成方式已经用一段时间了,今天刚好有时间,尝试下SDK.使用的话,也很方便,以下是简单的步骤1.新 ...
- POJ3070 矩阵快速幂模板
题目:http://poj.org/problem?id=3070 矩阵快速幂模板.mod写到乘法的定义部分就行了. 别忘了 I ( ) 和 i n i t ( ) 要传引用! #include< ...
- Linux内核 TCP/IP参数调优
http://www.360doc.com/content/14/0606/16/3300331_384326124.shtml
- Bootstrap-CL:进度条
ylbtech-Bootstrap-CL:进度条 1.返回顶部 1. Bootstrap 进度条 本章将讲解 Bootstrap 进度条.在本教程中,您将看到如何使用 Bootstrap 创建加载.重 ...