【LEETCODE】63、数组分类,hard级别,题目:85、4、84
package y2019.Algorithm.array.hard; /**
* @ProjectName: cutter-point
* @Package: y2019.Algorithm.array.hard
* @ClassName: MaximalRectangle
* @Author: xiaof
* @Description: TODO 85. Maximal Rectangle
* Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing only 1's and return its area.
*
* Input:
* [
* ["1","0","1","0","0"],
* ["1","0","1","1","1"],
* ["1","1","1","1","1"],
* ["1","0","0","1","0"]
* ]
* Output: 6
*
* 给定一个仅包含 0 和 1 的二维二进制矩阵,找出只包含 1 的最大矩形,并返回其面积。
*
* 如果是只包含的话,那么就需要计算面积
*
* @Date: 2019/7/26 16:54
* @Version: 1.0
*/
public class MaximalRectangle { public int solution(char[][] matrix){
//这里就是一行不一行的遍历,然后通过每一行的数据的
if(matrix == null || matrix.length <= 0) {
return 0;
} int rowLen = matrix.length;
int colLen = matrix[0].length; // 行 int left[] = new int[colLen], right[] = new int[colLen], height[] = new int[colLen]; //初始化
for(int j = 0; j < colLen; ++j) {
right[j] = colLen;
} //初始化right,用来标识这个直方图的右边坐标位置
int maxA = 0; //最大面积
for(int i = 0; i < rowLen; ++i) {
int curLeft = 0, curRight = colLen;
//循环遍历没一行
for(int j = 0; j < colLen; ++j) {
if(matrix[i][j] == '1') {
//如果是1,那么就是++高度
height[j]++;
} else {
height[j] = 0;//否则这个直方图的高度目前为0
}
} //计算左边坐标,从0开始,因为每当出现1的时候,我们就累加进去,如果没有出现1,是0,那么我们要把坐标起始位置向右边移动一位
//如果是1,那么以最大值为准,因为上一层的为1 的低位在这一层为0,那么就断掉了,不再这个直方图中
for(int j = 0; j < colLen; ++j) {
if(matrix[i][j] == '1') {
left[j] = Math.max(curLeft, left[j]);
} else {
//如果这个位置不是1,那么就要移动起始坐标
left[j] = 0;
curLeft = j + 1;
}
} //计算直方图右边坐标,这个应该从1开始,计算右边一直在矩阵内的坐标
for(int j = colLen - 1; j >= 0; --j) {
if(matrix[i][j] == '1') {
//这边取最小值,因为上一层有,这一层没有,那么就往左边缩
right[j] = Math.min(curRight, right[j]);
} else {
//如果这个位置不是1,那么就要移动起始坐标
right[j] = colLen;
curRight = j;
}
} //计算最大面积
for(int j = 0; j < colLen; ++j) {
maxA = Math.max(maxA, (right[j] - left[j]) * height[j]);
} } return maxA; } public static void main(String args[]) {
char data[][] = {{'1'}};
char data2[][] = {
{'1','0','1','0','0'},
{'1','0','1','1','1'},
{'1','1','1','1','1'},
{'1','0','0','1','0'}
};
MaximalRectangle fuc = new MaximalRectangle();
System.out.println(fuc.solution(data2));
} }
package y2019.Algorithm.array.hard; /**
* @ClassName FindMedianSortedArrays
* @Description TODO 4. Median of Two Sorted Arrays
*
* There are two sorted arrays nums1 and nums2 of size m and n respectively.
* Find the median of the two sorted arrays. The overall run time complexity should be O(log (m+n)).
* You may assume nums1 and nums2 cannot be both empty.
*
* nums1 = [1, 3]
* nums2 = [2]
*
* The median is 2.0
*
* 参考:https://www.youtube.com/watch?v=LPFhl65R7ww
* @Author xiaof
* @Date 2019/7/28 16:32
* @Version 1.0
**/
public class FindMedianSortedArrays { public double solution(int[] nums1, int[] nums2) {
if(nums1.length > nums2.length) {
return solution(nums2, nums1); //我们需要根据长度小的中间位置计算另外一个长的位置的分割点
} //获取总长
int x = nums1.length;
int y = nums2.length; //计算区间
int low = 0, hight = x; //根据第一个数组进行分割
while (low <= hight) {
//只要瞒住条件,就一直循环,核心思想还是二分查找
//开始分割
int partitionx = (low +hight) / 2;
int partitiony = (x + y + 1) / 2 - partitionx; //计算第二个数组的分割点,对于和是奇数的情况+1,可以向右边移动一位保证中间数据在左边,这样就不用判断左右了 //计算两个数组中被分割的临近中间位置的数据,如果分割位置是0,那也就左边没有元素不用比较计算,直接设置最小值
int maxLeftx = partitionx == 0 ? Integer.MIN_VALUE : nums1[partitionx - 1];
int minRightx = partitionx == x ? Integer.MAX_VALUE : nums1[partitionx]; //右边最小位置 int maxLefty = partitiony == 0 ? Integer.MIN_VALUE : nums2[partitiony - 1];
int minRighty = partitiony == y ? Integer.MAX_VALUE : nums2[partitiony]; //分三种情况,第一张找到了
if(maxLeftx <= minRighty && maxLefty <= minRightx) {
//因为本身已经排好顺序,那么只要瞒住这个条件,那么就可以说这2个集合正好被分成了2块
//判断一共是奇数个还是偶数个
if((x + y) % 2 == 0) {
//偶数求平均值
return ((double) Math.max(maxLeftx, maxLefty) + Math.min(minRightx, minRighty)) / 2;
} else {
return (double) Math.max(maxLeftx, maxLefty);
}
} else if (maxLeftx > minRighty) {
//如果左边的第一个序列的最大值比第二个序列右边最小值大,说明不是中分的数据,说明第一个序列分割的位置太大了,我们把这个元素划归到右边去
hight = partitionx - 1;
} else {
//maxLefty 》 minRightx 右边第一个序列的最小值比下面的序列的最大值小,说明高位给低了
low = partitionx + 1;
}
} //最后出现异常情况,那就是如果序列没排序,那就GG
return -1; } public static void main(String args[]) {
int input1[] = {1,3};
int input2[] = {2};
FindMedianSortedArrays fuc = new FindMedianSortedArrays();
System.out.println(fuc.solution(input1, input2));
} }
package y2019.Algorithm.array.hard; /**
* @ClassName LargestRectangleArea
* @Description TODO 84. Largest Rectangle in Histogram
* Given n non-negative integers representing the histogram's bar height where the width of each bar is 1, find the area of largest rectangle in the histogram.
* @Author xiaof
* @Date 2019/7/28 21:44
* @Version 1.0
**/
public class LargestRectangleArea { public int solution(int[] heights) {
if(heights == null || heights.length <= 0) {
return 0;
} //求最大面积,参考85. Maximal Rectangle ,可以用同样的思路求解
//同样我们需要找到这个直方图的左边界,右边界,然后整合所有直方图的最大值
int left[] = new int[heights.length], right[] = new int[heights.length]; //遍历所有直方图,并根据当前直方图获取左右两边的位置 left
left[0] = -1;
for(int i = 1; i < heights.length; ++i) {
int p = i - 1;
while (p >= 0 && heights[p] >= heights[i]) {
// --p;
//这里不用每次都遍历,直接使用上次的结果就可以了
p = left[p];
}
//设置这个最左边的坐标
left[i] = p;
} //设置右边
right[heights.length - 1] = heights.length;
for(int i = heights.length - 2; i >= 0; --i) {
int p = i + 1;
while (p < heights.length && heights[p] >= heights[i]) {
// ++p;
//这里不用每次都遍历,直接使用上次的结果就可以了
p = right[p];
}
right[i] = p;
} //求面积maxa = Math.max{maxa, heights[i] * (right[i] - left[i] - 1)}
int maxa = 0;
for(int i = 0; i < heights.length; ++i) {
maxa = Math.max(maxa, heights[i] * (right[i] - left[i] - 1));
} return maxa; } public static void main(String args[]) {
int data[] = {2,1,5,6,2,3};
LargestRectangleArea fuc = new LargestRectangleArea();
System.out.println(fuc.solution(data));
} }
【LEETCODE】63、数组分类,hard级别,题目:85、4、84的更多相关文章
- LeetCode:颜色分类【75】
		LeetCode:颜色分类[75] 题目描述 给定一个包含红色.白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色.白色.蓝色顺序排列. 此题中,我们使用整数 ... 
- LeetCode.961-2N数组中N次重复的元素(N-Repeated Element in Size 2N Array)
		这是悦乐书的第365次更新,第393篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第227题(顺位题号是961).在大小为2N的数组A中,存在N+1个唯一元素,并且这些元 ... 
- [LeetCode] All questions numbers conclusion 所有题目题号
		Note: 后面数字n表明刷的第n + 1遍, 如果题目有**, 表明有待总结 Conclusion questions: [LeetCode] questions conclustion_BFS, ... 
- LeetCode:数组中的第K个最大元素【215】
		LeetCode:数组中的第K个最大元素[215] 题目描述 在未排序的数组中找到第 k 个最大的元素.请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素. 示例 1: ... 
- LeetCode一维数组的动态和
		一维数组的动态和 题目描述 给你一个数组 nums.数组「动态和」的计算公式为:runningSum[i] = sum(nums[0]...nums[i]). 请返回 nums 的动态和. 示例 1: ... 
- 【LEETCODE】56、数组分类,适中级别,题目:62、63、1035
		package y2019.Algorithm.array.medium; /** * @ClassName UniquePathsWithObstacles * @Description TODO ... 
- 【LEETCODE】61、对leetcode的想法&数组分类,适中级别,题目:162、73
		这几天一直再想这样刷题真的有必要么,这种单纯的刷题刷得到尽头么??? 这种出题的的题目是无限的随便百度,要多少题有多少题,那么我这一直刷的意义在哪里??? 最近一直苦苦思考,不明所以,刷题刷得更多的感 ... 
- 【LEETCODE】54、数组分类,简单级别,题目:605、532
		数组类,简单级别完结.... 不容易啊,基本都是靠百度答案.... 希望做过之后后面可以自己复习,自己学会这个解法 package y2019.Algorithm.array; /** * @Proj ... 
- 【LEETCODE】53、数组分类,简单级别,题目:989、674、1018、724、840、747
		真的感觉有点难... 这还是简单级别... 我也是醉了 package y2019.Algorithm.array; import java.math.BigDecimal; import java. ... 
随机推荐
- Linux下g++编译thread出错的的解决方法
			错误如下图所示: 因为thread是C++11新加入的特性,所以我们在用g++编译的时候不能直接用,需要在g++后面加上 -std=c++0x -pthread 如果是gcc编译多线程的话则应该要用 ... 
- .NET总结--泛型与泛型集合,应用场景
			泛型优点 1.提高代码复用性,代码简洁直观 2.直接存储数据类型免去数据类型之间得隐式转换 3.免去拆箱装箱过程,提高效率 4.数据类型安全,存储时会验证是否对应该类型 泛型集合 一. ArrayLi ... 
- 利用python爬虫爬取图片并且制作马赛克拼图
			想在妹子生日送妹子一张用零食(或者食物类好看的图片)拼成的马赛克拼图,因此探索了一番= =. 首先需要一个软件来制作马赛克拼图,这里使用Foto-Mosaik-Edda(网上也有在线制作的网站,但是我 ... 
- tidyr
			tidyr包主要提供了数据整理和清洗的功能,包括 1. 数据框的变形 2. 处理数据框中的空值 3. 根据一个表格衍生出其他表格 4. 实现行或列的分隔和合并 该包将要用的数据处理成标准且统一的数据框 ... 
- shell 命令行参数(getopt和getopts)
			getopt 命令 使用getopt命令,可以解析任何命令行选项和参数,但是用法比较复杂.getopt的命令用法如下: $ getopt --help 用法: getopt optstring par ... 
- MySQL之replace函数应用
			replace函数,从字面上看其主要作用就是替换.实际它的作用确实是替换.那么替换有哪些应用场景呢?比如A表和B表有一个关联的字段就是id,但是在A中id是数字,在B中id也是数字,但是B中id多一个 ... 
- 数据库与spring事务传播特性
			一.spring事务管理的实现原理,基于AOP 1) REQUIRED ,这个是默认的属性 Support a current transaction, create a new one if non ... 
- kafka如何实现高并发存储-如何找到一条需要消费的数据(阿里)
			阿里太注重原理了:阿里问kafka如何实现高并发存储-如何找到一条需要消费的数据,kafka用了稀疏索引的方式,使用了二分查找法,其实很多索引都是二分查找法 二分查找法的时间复杂度:O(logn) ... 
- [技术博客]react native事件监听、与原生通信——实现对通知消息的响应
			在react native中会涉及到很多页面之间的参数传递问题.静态的参数传递通常利用组件的Props属性,在初始化组件时即可从父组件中将参数传递到子组件中.对于非父子关系的组件来说,无法直接传递参数 ... 
- [Gamma]Scrum Meeting#4
			github 本次会议项目由PM召开,时间为5月29日晚上10点30分 时长10分钟 任务表格 人员 昨日工作 下一步工作 木鬼 撰写博客,组织例会 撰写博客,组织例会 swoip 前端显示屏幕,翻译 ... 
