这是悦乐书的第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,就可以组成三角形。

思路:利用Arrayssort方法,对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)的更多相关文章

  1. LeetCode 976. 三角形的最大周长(Largest Perimeter Triangle) 33

    976. 三角形的最大周长 976. Largest Perimeter Triangle 题目描述 给定由一些正数(代表长度)组成的数组 A,返回由其中三个长度组成的.面积不为零的三角形的最大周长. ...

  2. 【Leetcode_easy】976. Largest Perimeter Triangle

    problem 976. Largest Perimeter Triangle solution: class Solution { public: int largestPerimeter(vect ...

  3. [Swift]LeetCode976. 三角形的最大周长 | Largest Perimeter Triangle

    Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero area, ...

  4. 【LeetCode】976. Largest Perimeter Triangle 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 排序 日期 题目地址:https://leetcod ...

  5. LeetCode 976 Largest Perimeter Triangle 解题报告

    题目要求 Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero ...

  6. 【leetcode】976. Largest Perimeter Triangle

    题目如下: Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero ...

  7. 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, ...

  8. 976. Largest Perimeter Triangle

    Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero area, ...

  9. LeetCode 976. Largest Perimeter Triangle (三角形的最大周长)

    题目标签:Array 题目给了我们一个 边长的 array, 让我们找出 最大边长和的三角形,当然前提得是这三条边能组成三角形.如果array 里得边长组成不了三角形,返回0. 最直接的理解就是,找到 ...

随机推荐

  1. HDU - 6087 Rikka with Sequence (可持久化treap+倍增+重构)

    题目链接 感谢Dream_Lolita的题解,经过无数次失败的尝试之后终于AC了... 线段树是维护区间信息的强大工具,但它的形态是固定的,只支持修改和删除操作,不支持插入.反转.复制.分裂合并等操作 ...

  2. 使用IDEA搭建一个 Spring + Spring MVC + Mybatis 的Web项目 ( 零配置文件 )

    前言: 除了mybatis 不是零配置,有些还是有xml的配置文件在里面的. 注解是Spring的一个构建的一个重要手段,减少写配置文件,下面解释一下一些要用到的注解: @Configuration  ...

  3. 【NOIP2017提高A组集训10.21】Fantasy

    题目 Y sera 陷入了沉睡,幻境中它梦到一个长度为N 的序列{Ai}. 对于这个序列的每一个子串,定义其幻境值为这个子串的和,现在Y sera 希望选择K 个不同的子串并使得这K 个子串的幻境值之 ...

  4. 对组件、Prop 和 State的研究-----------------引用

    组件 第一步是将 UI 分解成多个组件.例如,我们可以这样来拆分房子: 现在来编码! House:  <div>    <Roof />     // 房顶    <Wa ...

  5. C#定时任务之FluentScheduler

    一.业务需求 平台首页,有几个指标统计,产品不要求实时性,觉得一天更新一次可以接受. 最后决定用FluentScheduler定时执行统计,redis缓存结果. 每天晚上1点进行定时任务统计,将统计结 ...

  6. vue 安装scss

    1.安装插件 npm install node-sass --save-devnpm install sass-loader --save-dev 在App页面测试是否可用,在style 上添加< ...

  7. [CSP-S模拟测试]:字符交换(贪心+模拟)

    题目传送门(内部题136) 输入格式 输入文件第一行为两个正整数$n,k$,第二行为一个长度为$n$的小写字母字符串$s$. 输出格式 输出一个整数,为对字符串$s$进行至多$k$次交换相邻字符的操作 ...

  8. 分布式-信息方式-ActiveMQ基础

    ActiveMQ简介 ActiveMQ是什么ActiveMQ是Apache推出的,一款开源全支持JMS.1和J2EE1.4范的JMS Provider实现的信息中间件.(message oriente ...

  9. SQLite索引

    索引(Index)是一种特殊的查找表,数据库搜索引擎用来加快数据检索.简单地说,索引是一个指向表中数据的指针.一个数据库中的索引与一本书后边的索引是非常相似的. 例如,如果您想在一本讨论某个话题的书中 ...

  10. 剑指offer32----之字形打印一颗二叉树

    题目 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. 思路 在这里我们如果单纯的使用队列去弄的话,会很 ...