给定两个矩形的边的长度,我必须编写代码来检查第一个矩形是否能被第二个矩形完全覆盖。可以只旋转第二个矩形,看看它是否能覆盖第一个矩形。
A和B是我们要覆盖的第一个矩形的边的长度,C和D是第二个矩形的边的长度,这个矩形将覆盖第一个矩形。
我已经尝试了两个代码,但仍然不起作用。第一种是天真的解决方案,但我不知道它是否正确。
A, B, C, D = map(int, input().split())
if (C >= A and D >= B) or (C >= B and D >= A):
print("covered")然后我用我的数学技巧发现第二个矩形(l1和l2)的边应该是l1 >= A*sin(a) + B*cos(a)和l2 >= A*cos(a) + B*sin(a)。a是一个可以0到90º的角度。所以我的第二个代码是:
A, B, C, D = map(int, input().split())
import math
a = 0
while a <= 90 and value == False:
ai = math.radians(a)
t1 = math.ceil(A*math.cos(ai) + B*math.sin(ai))
t2 = math.ceil(A*math.sin(ai) + B*math.cos(ai))
if (C >= t1 and D >= t2) :
value = True
a = a + 1它适用于我做的一些测试,但我的代码没有得到正确的答案。那么,我能做什么来解决这个问题呢?我的想法正确吗?
如果我犯了语法、句法或数学上的任何其他错误,请随时纠正我。
发布于 2019-07-15 22:33:16
我认为你只需要检查三个案例:
你不需要检查任何随机的角度。如果它在任何一般情况下都重叠,则必须在上述三种情况之一中这样做。
第三种情况是极限情况:考虑正方形中类似矩形的杆子。
发布于 2019-07-15 22:28:53
在你的代码中并不清楚矩形边的长度到底是多少。
但不应该有任何涉及角度的计算:当且仅当A时,B可以完全覆盖A.length <= B.lenght and A.width <= B.width。
(抱歉,我不能发表评论)
https://stackoverflow.com/questions/57041540
复制相似问题