LeetCode #976 三角形最大周长
程序员文章站
2022-04-01 12:12:54
...
思想:
组成三角形的充要条件:a+b>c。
将A排序后,为了使周长最大,肯定是从后往前取,从最后一位c开始,依次判断前两位的数a, b之和是否比它大,只要满足,那a+c>b和b+c>a又一定成立(c已经大于a/b了),则abc可以构成三角形,且此时周长最大;如果不能满足,就继续往前找,直到找完所有A中元素。
class Solution:
def largestPerimeter(self, A: List[int]) -> int:
res = 0
l = len(A)
if l<3:
return res
A.sort()
for i in range(l-1, 1, -1):
if A[i] < A[i-1] + A[i-2]:
return A[i] + A[i-1] + A[i-2]
return res