363. Trapping Rain Water

 public class Solution {
/**
* @param heights: a list of integers
* @return: a integer
*/
public int trapRainWater(int[] heights) {
// write your code here
if (heights == null || heights.length == 0) {
return 0;
} int start = 0;
int end = heights.length - 1;
int maxLeft = Integer.MIN_VALUE;
int maxRight = Integer.MIN_VALUE;
int sum = 0;
while (start < end) {
maxLeft = heights[start] > maxLeft ? heights[start] : maxLeft;
maxRight = heights[end] > maxRight ? heights[end] : maxRight;
if (maxLeft < maxRight) {
sum += maxLeft - heights[start];
start++;
} else {
sum += maxRight - heights[end];
end--;
}
}
return sum;
}
}

364. Trapping Rain Water II

 class Point {
int x;
int y;
int height; public Point(int x, int y, int height) {
this.x = x;
this.y = y;
this.height = height;
}
} public class Solution {
/**
* @param heights: a matrix of integers
* @return: an integer
*/ int[] dx = {0, 1, 0, -1};
int[] dy = {1, 0, -1, 0}; public int trapRainWater(int[][] heights) {
// write your code here
if (heights == null || heights.length == 0 || heights[0].length == 0) {
return 0;
}
int r = heights.length;
int c = heights[0].length;
boolean[][] visited = new boolean[r][c]; Comparator<Point> minComparator = new Comparator<Point>() {
@Override
public int compare(Point o1, Point o2) {
return o1.height - o2.height;
}
}; PriorityQueue<Point> minHeap = new PriorityQueue<>(minComparator); for (int i = 0; i < r; i++) {
minHeap.add(new Point(i, 0, heights[i][0]));
visited[i][0] = true;
minHeap.add(new Point(i, c - 1, heights[i][c - 1]));
visited[i][c - 1] = true;
} for (int j = 0; j < c; j++) {
minHeap.add(new Point(0, j, heights[0][j]));
visited[0][j] = true;
minHeap.add(new Point(r - 1, j, heights[r - 1][j]));
visited[r - 1][j] = true;
} int sum = 0;
while (!minHeap.isEmpty()) {
Point point = minHeap.poll(); for (int i = 0; i < 4; i++) {
int nx = point.x + dx[i];
int ny = point.y + dy[i];
if (!isValid(nx, ny, heights, visited)) {
continue;
} visited[nx][ny] = true;
minHeap.add(new Point(nx, ny, Math.max(heights[nx][ny], point.height)));
sum += Math.max(heights[nx][ny], point.height) - heights[nx][ny];
}
}
return sum; } public boolean isValid(int x, int y, int[][] heights, boolean[][] visited) {
if (x < 0 || x > heights.length - 1 || y < 0 || y > heights[0].length - 1) {
return false;
}
if (visited[x][y]) {
return false;
}
return true;
}
}

360. Sliding Window Median 具体思路见  81. Find Median from Data Stream

 public class Solution {
/**
* @param nums: A list of integers
* @param k: An integer
* @return: The median of the element inside the window at each moving
*/
private PriorityQueue<Integer> minHeap;
private PriorityQueue<Integer> maxHeap;
private int maxSize = 0;
private int minSize = 0; public List<Integer> medianSlidingWindow(int[] nums, int k) {
// write your code here
if (nums == null || nums.length < k || k <= 0) {
return new ArrayList<>();
} minHeap = new PriorityQueue<>();
maxHeap = new PriorityQueue<>(new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
return o2.compareTo(o1);
}
});
List<Integer> res = new ArrayList<>(); for (int i = 0; i < k; i++) {
addNumber(nums[i]);
}
res.add(getMedian());
for (int j = k; j < nums.length; j++) {
slideByWindow(nums[j], nums[j - k]);
res.add(getMedian());
}
return res;
} public void addNumber(int num) {
maxHeap.add(num);
maxSize++;
if (maxSize - minSize <= 1) {
if (minHeap.isEmpty()) {
return;
} if (maxHeap.peek() > minHeap.peek()) {
int maxTemp = maxHeap.poll();
int minTemp = minHeap.poll();
minHeap.add(maxTemp);
maxHeap.add(minTemp);
}
return;
} minHeap.add(maxHeap.poll());
minSize++;
maxSize--;
} public int getMedian() {
return maxHeap.peek();
} public void slideByWindow(int toAdd, int toRemove) {
if (toRemove <= getMedian()) {
maxHeap.remove(toRemove);
maxSize--;
} else {
minHeap.remove(toRemove);
minSize--;
}
addNumber(toAdd);
}
}

Heap — 20181120的更多相关文章

  1. java head space/ java.lang.OutOfMemoryError: Java heap space内存溢出

    上一篇JMX/JConsole调试本地还可以在centos6.5 服务器上进行监控有个问题端口只开放22那么设置的9998端口 你怎么都连不上怎么监控?(如果大神知道还望指点,个人见解) 线上项目出现 ...

  2. Java 堆内存与栈内存异同(Java Heap Memory vs Stack Memory Difference)

    --reference Java Heap Memory vs Stack Memory Difference 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有 ...

  3. [数据结构]——堆(Heap)、堆排序和TopK

    堆(heap),是一种特殊的数据结构.之所以特殊,因为堆的形象化是一个棵完全二叉树,并且满足任意节点始终不大于(或者不小于)左右子节点(有别于二叉搜索树Binary Search Tree).其中,前 ...

  4. Windbg Extension NetExt 使用指南 【3】 ---- 挖掘你想要的数据 Managed Heap

    摘要 : NetExt中有两个比较常用的命令可以用来分析heap上面的对象. 一个是!wheap, 另外一个是!windex. !wheap 这个命令可以用于打印出heap structure信息. ...

  5. JAVA Shallow heap & Retained heap

    最近在研究内存泄漏的问题,在使用MAT工具中发现了Shallow heap & Retained heap,不懂. 然后在网上找了一些资料. Shallow Size 对象自身占用的内存大小, ...

  6. 笔记:程序内存管理 .bss .data .rodata .text stack heap

    1.未初始化的全局变量(.bss段) bss段用来存放 没有被初始化 和 已经被初始化为0 的全局变量.如下例代码: #include<stdio.h> int bss_array[102 ...

  7. STL heap usage

    简介 heap有查找时间复杂度O(1),查找.插入.删除时间复杂度为O(logN)的特性,STL中heap相关的操作如下: make_heap() push_heap() pop_heap() sor ...

  8. Nodemanager Out of heap memory[fix bug全过程]

    问题: 自己写了一个yarn上的application,发现nodemanager过段时间,会out of memory退出,把nodemanager的heap memory从1G增大到2G也是无法避 ...

  9. Git使用出错:Couldn‘t reserve space for cygwin‘s heap, Win32

    今天使用Git在命令行下更新代码遇到了问题,起初觉得是自己安装某软件导致冲突,从网上搜索了一下找到类似问题,成功解决问题. 错误信息如下: E:\storm-sql>git pull origi ...

随机推荐

  1. php手机号正则

    preg_match("/^1[34578]{1}\d{9}$/", $phone)

  2. SpringMVC——RequestMapping

    一.@RequestMapping 映射请求 Spring MVC 通过@RequestMapping注解可以定义不同的处理器映射规则. @RequestMapping放在类名上边,设置请求前缀 方法 ...

  3. 简单的Cooki案例——记录用户上次访问该网页的时间

    功能: 帮助网站实现提示客户端计算机上次访问网站的时间 实现原理: 将每一个会话作为一次访问过程,将每次会话的开始时间作为每次访问网站的时间,然后将这个时间以Cookie的形式存储到客户端的计算机中, ...

  4. Web大文件上传控件-示例更新-Xproer.HttpUploader6.2

    版权所有 2009-2016荆门泽优软件有限公司 保留所有权利 官方网站:http://www.ncmem.com/ 产品首页:http://www.ncmem.com/webapp/up6.2/in ...

  5. C# 取得内网IP、外网IP、客户端IP方法

    前言 在 Windows Form Application 里对于取得 IP Address 有内网.外网两种 IP Address ,如果只需要取得内网 IP Address ,可以透过使用 IPH ...

  6. 中介者(Mediator)模式

    中介者(Mediator)模式:用一个中介对象来封装一系列的对象交互,中介者使各个对象不需要显示的相互引用,从而使得耦合松散,而且可以独立的改变他们之间的交互 了解<迪米特法则>的朋友就知 ...

  7. 停止Nginx服务

    查询nginx进程信息 chen@ubuntu:~$ ps -ef |grep nginx root : ? :: nginx: master process /usr/sbin/nginx -g d ...

  8. android和.net webservice中的DES加密算法

    也是看了一堆的例子,本身并不会写加密算法,好在只要会用就行了,我们把在app中使用的参数加密,然后在.net端的webservice中进行解密,本身并没有什么问题,但是android下和.net下的d ...

  9. C# 调接口

    上一个项目,需要mvc管理后台调接口项目,以便后期的重构扩展,调研后发现后台用的ajax请求,直接调接口可能会有跨域问题,最终在c#代码中实现了这个需求. 1,Ajax请求后台 将接口所需参数传入 2 ...

  10. 正确处理类的复合关系------新标准c++程序设计

    假设要编写一个小区养狗管理程序,该程序需要一个“主人”类,还需要一个“狗”类.狗是有主人的,主人也有狗.假定狗只有一个主人,但一个主人可以有最多10条狗.该如何处理“主人”类和“狗”类的关系呢?下面是 ...