forked from YuriSpiridonov/LeetCode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1725.NumberOfRectanglesThatCanFormTheLargestSquare.py
49 lines (40 loc) · 1.68 KB
/
1725.NumberOfRectanglesThatCanFormTheLargestSquare.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
'''
You are given an array rectangles where rectangles[i] = [li, wi]
represents the ith rectangle of length li and width wi.
You can cut the ith rectangle to form a square with a
side length of k if both k <= li and k <= wi. For
example, if you have a rectangle [4,6], you can cut it
to get a square with a side length of at most 4.
Let maxLen be the side length of the largest square you
can obtain from any of the given rectangles.
Return the number of rectangles that can make a square
with a side length of maxLen.
Example:
Input: rectangles = [[5,8],[3,9],[5,12],[16,5]]
Output: 3
Explanation: The largest squares you can get from each
rectangle are of lengths [5,3,5,5].
The largest possible square is of length 5,
and you can get it out of 3 rectangles.
Example:
Input: rectangles = [[2,3],[3,7],[4,3],[3,7]]
Output: 3
Constraints:
-1 <= rectangles.length <= 1000
-rectangles[i].length == 2
-1 <= li, wi <= 10^9
-li != wi
'''
#Difficulty: Easy
#68 / 68 test cases passed.
#Runtime: 176 ms
#Memory Usage: 14.8 MB
#Runtime: 176 ms, faster than 100.00% of Python3 online submissions for Number Of Rectangles That Can Form The Largest Square.
#Memory Usage: 14.8 MB, less than 66.67% of Python3 online submissions for Number Of Rectangles That Can Form The Largest Square.
from collections import defaultdict
class Solution:
def countGoodRectangles(self, rectangles: List[List[int]]) -> int:
squares = defaultdict(int)
for rectangle in rectangles:
squares[min(rectangle)] += 1
return squares[max(squares)]