LeetCode.976-周长最大的三角形(Largest Perimeter Triangle)
这是悦乐书的第368次更新,第396篇原创
01 看题和准备
今天介绍的是LeetCode算法题中Easy级别的第230题(顺位题号是976)。给定正长度的数组A,返回具有非零区域的三角形的最大周长,由这些长度中的3个组成。如果不可能形成任何非零区域的三角形,则返回0。例如:
输入:[2,1,2]
输出:5
输入:[1,2,1]
输出:0
输入:[3,2,3,4]
输出:10
输入:[3,6,2,3]
输出:8
注意:
3 <= A.length <= 10000
1 <= A[i] <= 10^6
02 第一种解法
暴力解法,会超时。
题目的意思是从数组中拿三个数组成三角形,求最大周长,如果找不到适合的数组成三角形,就返回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;
}
03 第二种解法
第一种解法的时间复杂度太高了,我们需要再优化下,既然是数组,并且需要一次拿三个数,那能够想到的就是先排序了,取相邻的三个元素,以这三个元素作为三角形的边长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;
}
04 小结
算法专题目前已连续日更超过七个月,算法题文章236+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。
以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!
LeetCode.976-周长最大的三角形(Largest Perimeter Triangle)的更多相关文章
- LeetCode 976. 三角形的最大周长(Largest Perimeter Triangle) 33
976. 三角形的最大周长 976. Largest Perimeter Triangle 题目描述 给定由一些正数(代表长度)组成的数组 A,返回由其中三个长度组成的.面积不为零的三角形的最大周长. ...
- 【Leetcode_easy】976. Largest Perimeter Triangle
problem 976. Largest Perimeter Triangle solution: class Solution { public: int largestPerimeter(vect ...
- [Swift]LeetCode976. 三角形的最大周长 | Largest Perimeter Triangle
Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero area, ...
- 【LeetCode】976. Largest Perimeter Triangle 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 排序 日期 题目地址:https://leetcod ...
- LeetCode 976 Largest Perimeter Triangle 解题报告
题目要求 Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero ...
- 【leetcode】976. Largest Perimeter Triangle
题目如下: Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero ...
- 119th LeetCode Weekly Contest Largest Perimeter Triangle
Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero area, ...
- 976. Largest Perimeter Triangle
Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero area, ...
- LeetCode 976. Largest Perimeter Triangle (三角形的最大周长)
题目标签:Array 题目给了我们一个 边长的 array, 让我们找出 最大边长和的三角形,当然前提得是这三条边能组成三角形.如果array 里得边长组成不了三角形,返回0. 最直接的理解就是,找到 ...
随机推荐
- Spring如何对私有接口进行注入(转载)
来自:http://didiluck.iteye.com/blog/1779640 Spring 标注@Autowired 如果做到自动装配私有变量而不使用set方法的原理 熟悉jdk的话就知道,方 ...
- mvn高级构建
指定pom文件,打包指定的module,并且自动打包这个模块所依赖的其他模块. mvn clean install -f vmc-business-parent/pom.xml -pl vmc-sch ...
- 有关 CMMI
CMMI的全称为Capability Maturity Model Integration,即能力成熟度模型集成.CMMI是CMM模型的最新版本.早期的CMMI(CMMI-SE/SW/IPPD),SE ...
- iview 在Table组件中使用switch组件并自定义内容和增加自定义事件
注意: 使用render函数. 效果: 添加自定义文字: 1. 2. 上面的两种方法效果都是一样的: 增加自定义事件: 结果: 自信是进步的源泉. 继续加油. ^_^
- fedora29 下一款截图工具shutter的安装和调试
运行命令安装shutter sudo yum install shutter 如果使用过程中出现花屏 sudo vim /etc/gdm/custom.conf 把 #WaylandEnabled=f ...
- MongoDB学习笔记之文档
#向集合中插入文档有两种方式(insert.save) db.col.insert({title: 'MongoDB 教程', description: 'MongoDB 是一个 Nosql 数据库' ...
- 【leetcode】1239. Maximum Length of a Concatenated String with Unique Characters
题目如下: Given an array of strings arr. String s is a concatenation of a sub-sequence of arr which have ...
- Python 面向对象Ⅲ
Python内置类属性 __dict__ : 类的属性(包含一个字典,由类的数据属性组成) __doc__ :类的文档字符串 __name__: 类名 __module__: 类定义所在的模块http ...
- node监视文件或者文件夹的变化
1.node提供一个watch这个API,可以监视文件或文件夹的变化,当发生改变时,做出某些操作.(当做代码本地构建时,经常使用) const fs = require('fs'); fs.watch ...
- jprofiler 监听远程java项目
1.下载.安装windows和linux版的jprofile.注意:若监控的是springboot.springcloud项目,切记本地和服务器上的jprofile要版本保持一致,本人亲自踩过坑. 官 ...