1725:可以形成最大正方形的矩形数目
This commit is contained in:
parent
8e52631b4a
commit
610ac38b84
@ -0,0 +1,69 @@
|
|||||||
|
//给你一个数组 rectangles ,其中 rectangles[i] = [li, wi] 表示第 i 个矩形的长度为 li 、宽度为 wi 。
|
||||||
|
//
|
||||||
|
// 如果存在 k 同时满足 k <= li 和 k <= wi ,就可以将第 i 个矩形切成边长为 k 的正方形。例如,矩形 [4,6] 可以切成边长最大为
|
||||||
|
//4 的正方形。
|
||||||
|
//
|
||||||
|
// 设 maxLen 为可以从矩形数组 rectangles 切分得到的 最大正方形 的边长。
|
||||||
|
//
|
||||||
|
// 请你统计有多少个矩形能够切出边长为 maxLen 的正方形,并返回矩形 数目 。
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// 示例 1:
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//输入:rectangles = [[5,8],[3,9],[5,12],[16,5]]
|
||||||
|
//输出:3
|
||||||
|
//解释:能从每个矩形中切出的最大正方形边长分别是 [5,3,5,5] 。
|
||||||
|
//最大正方形的边长为 5 ,可以由 3 个矩形切分得到。
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// 示例 2:
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//输入:rectangles = [[2,3],[3,7],[4,3],[3,7]]
|
||||||
|
//输出:3
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// 提示:
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// 1 <= rectangles.length <= 1000
|
||||||
|
// rectangles[i].length == 2
|
||||||
|
// 1 <= li, wi <= 10⁹
|
||||||
|
// li != wi
|
||||||
|
//
|
||||||
|
// Related Topics 数组 👍 48 👎 0
|
||||||
|
|
||||||
|
package leetcode.editor.cn;
|
||||||
|
|
||||||
|
//1725:可以形成最大正方形的矩形数目
|
||||||
|
class NumberOfRectanglesThatCanFormTheLargestSquare {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
//测试代码
|
||||||
|
Solution solution = new NumberOfRectanglesThatCanFormTheLargestSquare().new Solution();
|
||||||
|
}
|
||||||
|
|
||||||
|
//力扣代码
|
||||||
|
//leetcode submit region begin(Prohibit modification and deletion)
|
||||||
|
class Solution {
|
||||||
|
public int countGoodRectangles(int[][] rectangles) {
|
||||||
|
int maxLength = 0;
|
||||||
|
int count = 0;
|
||||||
|
for (int[] rectangle : rectangles) {
|
||||||
|
int temp = Math.min(rectangle[0], rectangle[1]);
|
||||||
|
if (temp == maxLength) {
|
||||||
|
count++;
|
||||||
|
} else if (temp > maxLength) {
|
||||||
|
count = 1;
|
||||||
|
maxLength = temp;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//leetcode submit region end(Prohibit modification and deletion)
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,37 @@
|
|||||||
|
<p>给你一个数组 <code>rectangles</code> ,其中 <code>rectangles[i] = [l<sub>i</sub>, w<sub>i</sub>]</code> 表示第 <code>i</code> 个矩形的长度为 <code>l<sub>i</sub></code> 、宽度为 <code>w<sub>i</sub></code> 。</p>
|
||||||
|
|
||||||
|
<p>如果存在 <code>k</code> 同时满足 <code>k <= l<sub>i</sub></code> 和 <code>k <= w<sub>i</sub></code> ,就可以将第 <code>i</code> 个矩形切成边长为 <code>k</code> 的正方形。例如,矩形 <code>[4,6]</code> 可以切成边长最大为 <code>4</code> 的正方形。</p>
|
||||||
|
|
||||||
|
<p>设 <code>maxLen</code> 为可以从矩形数组 <code>rectangles</code> 切分得到的 <strong>最大正方形</strong> 的边长。</p>
|
||||||
|
|
||||||
|
<p>请你统计有多少个矩形能够切出边长为<em> </em><code>maxLen</code> 的正方形,并返回矩形 <strong>数目</strong> 。</p>
|
||||||
|
|
||||||
|
<p> </p>
|
||||||
|
|
||||||
|
<p><strong>示例 1:</strong></p>
|
||||||
|
|
||||||
|
<pre>
|
||||||
|
<strong>输入:</strong>rectangles = [[5,8],[3,9],[5,12],[16,5]]
|
||||||
|
<strong>输出:</strong>3
|
||||||
|
<strong>解释:</strong>能从每个矩形中切出的最大正方形边长分别是 [5,3,5,5] 。
|
||||||
|
最大正方形的边长为 5 ,可以由 3 个矩形切分得到。
|
||||||
|
</pre>
|
||||||
|
|
||||||
|
<p><strong>示例 2:</strong></p>
|
||||||
|
|
||||||
|
<pre>
|
||||||
|
<strong>输入:</strong>rectangles = [[2,3],[3,7],[4,3],[3,7]]
|
||||||
|
<strong>输出:</strong>3
|
||||||
|
</pre>
|
||||||
|
|
||||||
|
<p> </p>
|
||||||
|
|
||||||
|
<p><strong>提示:</strong></p>
|
||||||
|
|
||||||
|
<ul>
|
||||||
|
<li><code>1 <= rectangles.length <= 1000</code></li>
|
||||||
|
<li><code>rectangles[i].length == 2</code></li>
|
||||||
|
<li><code>1 <= l<sub>i</sub>, w<sub>i</sub> <= 10<sup>9</sup></code></li>
|
||||||
|
<li><code>l<sub>i</sub> != w<sub>i</sub></code></li>
|
||||||
|
</ul>
|
||||||
|
<div><div>Related Topics</div><div><li>数组</li></div></div><br><div><li>👍 48</li><li>👎 0</li></div>
|
Loading…
Reference in New Issue
Block a user