Find the total area covered by two rectilinear rectangles in a 2D plane.
Each rectangle is defined by its bottom left corner and top right corner as shown in the figure.
Example:
Input: A = -3, B = 0, C = 3, D = 4, E = 0, F = -1, G = 9, H = 2
Output: 45
Note:
Assume that the total area is never beyond the maximum possible value of int.
矩形面积。题意是给两个矩形的左下角的坐标和右上角的坐标,请你返回由这两个矩形组成的多边形的面积。
思路是先计算两个矩形各自的面积,再计算两者重叠的部分,最后用两个矩形各自的面积 - 两者重叠的部分即可。各自计算两个长方形的面积这个很好处理,但是如何计算重叠部分的面积呢?这个题不要想复杂了,可以就参照题目给的例子来计算重叠部分的面积。对于这个重叠的部分,左下角的横坐标是A和E的较大值,右上角的横坐标是C和G的较小值,所以重叠部分的长是Math.min(C, G) - Math.max(A, E)。同理,重叠部分的高 = Math.min(D, H) - Math.max(B, F)。
时间O(1)
空间O(1)
Java实现
1 class Solution { 2 public int computeArea(int A, int B, int C, int D, int E, int F, int G, int H) { 3 int areaA = (C - A) * (D - B); 4 int areaB = (G - E) * (H - F); 5 int left = Math.max(A, E); 6 int right = Math.min(C, G); 7 int top = Math.min(D, H); 8 int bottom = Math.max(B, F); 9 10 int overlap = 0; 11 if (right > left && top > bottom) { 12 overlap = (right - left) * (top - bottom); 13 } 14 return areaA + areaB - overlap; 15 } 16 }
JavaScript实现
1 /** 2 * @param {number} A 3 * @param {number} B 4 * @param {number} C 5 * @param {number} D 6 * @param {number} E 7 * @param {number} F 8 * @param {number} G 9 * @param {number} H 10 * @return {number} 11 */ 12 var computeArea = function (A, B, C, D, E, F, G, H) { 13 let areaA = (C - A) * (D - B); 14 let areaB = (G - E) * (H - F); 15 let left = Math.max(A, E); 16 let right = Math.min(C, G); 17 let top = Math.min(D, H); 18 let bottom = Math.max(B, F); 19 20 let overlap = 0; 21 if (right > left && top > bottom) { 22 overlap = (right - left) * (top - bottom); 23 } 24 return areaA + areaB - overlap; 25 };