这是悦乐书的第368次更新,第396篇原创
java
今天介绍的是LeetCode
算法题中Easy
级别的第230
题(顺位题号是976
)。给定正长度的数组A
,返回具备非零区域的三角形的最大周长,由这些长度中的3个组成。若是不可能造成任何非零区域的三角形,则返回0。例如:算法
输入:[2,1,2]
输出:5数组
输入:[1,2,1]
输出:0数据结构
输入:[3,2,3,4]
输出:10优化
输入:[3,6,2,3]
输出:8code
注意:排序
3 <= A.length <= 10000class
1 <= A[i] <= 10^6
数据结构与算法
暴力解法,会超时。循环
题目的意思是从数组中拿三个数组成三角形,求最大周长,若是找不到适合的数组成三角形,就返回0。直接上循环,取三个数,拿到三个数后,利用三角形的定义:任意两边之和大于第三边,任意两边之差小于第三边。符合这两个条件就求三个数之和,最后取其中的最大值输出。
此解法的时间复杂度是O(N^3)
,空间复杂度是O(1)
。
public int largestPerimeter(int[] A) { int max = 0, len = A.length; for (int i=0; i<=len-2; i++) { for (int j=i+1; j<len-1; j++) { for (int k=j+1; k<len; k++) { if (isTriangle(A[i], A[j], A[k])) { max = Math.max(max, A[i]+A[j]+A[k]); } } } } return max; } public boolean isTriangle(int x, int y, int z) { boolean f = false, f2 = false; // 任意两边之和大于第三边 if (x+y>z && x+z>y && y+z>x) { f = true; } // 任意两边之差小于第三边 if (x-y<z && x-z<y && y-z<x) { f2 = true; } return f && f2; }
第一种解法的时间复杂度过高了,咱们须要再优化下,既然是数组,而且须要一次拿三个数,那可以想到的就是先排序了,取相邻的三个元素,以这三个元素做为三角形的边长a、b、c,他们的大小关系是a<=b<=c
,若是想要a、b、c
组成三角形,须要知足什么条件?
第一种状况:等边三角形,即a=b=c
,例如{3,3,3}。
第二种状况:等腰三角形,即a=b
或者b=c
,例如{4,4,5}、{2,6,6}。
第三种状况:普通三角形,即a<b<c
,例如{3,4,5}能够组成三角形,可是像{3,4,8}就不能组成三角形,虽然3,4,8知足a<b<c的关系。
因此,若是有a<=b<=c
的前提,那么只要a+b>c
,就能够组成三角形。
思路:利用Arrays
的sort
方法,对A
排序,从后往前每次取三个数,判断是否知足a+b>c
,知足此条件的三个数组成的三角形的周长是最大的。
此解法的时间复杂度是O(NlogN)
,空间复杂度是O(1)
。
public int largestPerimeter2(int[] A) { Arrays.sort(A); int n = A.length; for (int i=n-3; i>=0; i--) { if (A[i] + A[i+1] > A[i+2]) { return A[i] + A[i+1] + A[i+2]; } } return 0; }
算法专题目前已连续日更超过七个月,算法题文章236+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。
以上就是所有内容,若是你们有什么好的解法思路、建议或者其余问题,能够下方留言交流,点赞、留言、转发就是对我最大的回报和支持!