LeetCode 3024.三角形类型

目录

题目:

题目描述:

题目链接:

思路:

思路详解:

代码:

Java代码:


题目:

题目描述:

题目链接:

3024. 三角形类型 - 力扣(LeetCode)

思路:

思路详解:

先对nums进行排序,再按照题意进行判断

排序的意义:简化判断的逻辑

构成三角形的条件:任意两边之和大于第三边

如果输入的整数数组的三个边长度是无序的,按照任意两边之和大于第三边的条件我们需要判断三次。但是排序之后就只需要判断一次,假设排序后数组中的元素依次是a,b,c(a<=b<=c)。因为已经排序a是最小的,所以b+c>a一定成立。因为b<=c,所以a+c>b一定成立。所以判断能否构成三角形只需要判断a+b>c是否成立

小技巧:先把不合法的情况进行判断筛出去,再判断合法情况的具体部分能使代码更加简洁,可读性更搞

接下来在能构成三角形的情况下再细分判断,判断等边只需要判断a==c,不需要a==b&&b==c,因为我们已经进行了排序,a==c的情况下三条边一定都相等。判断等腰判断a==b||b==c即可。剩下的其他情况一定就是三条边的长度都不相等

代码:

Java代码:

复制代码
class Solution {
    public String triangleType(int[] nums) {
        Arrays.sort(nums);
        int a=nums[0];
        int b=nums[1];
        int c=nums[2];
        if(a+b<=c)
        {
            return "none";
        }
        if(a==c)
        {
            return "equilateral";
        }
        if(a==b||b==c)
        {
            return "isosceles";
        }
        return "scalene";
    }
}
相关推荐
yyy(十一月限定版)8 分钟前
寒假集训4——二分排序
算法
星火开发设计8 分钟前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
醉颜凉19 分钟前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
达文汐22 分钟前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗22 分钟前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
User_芊芊君子22 分钟前
【LeetCode经典题解】搞定二叉树最近公共祖先:递归法+栈存路径法,附代码实现
算法·leetcode·职场和发展
培风图南以星河揽胜22 分钟前
Java版LeetCode热题100之零钱兑换:动态规划经典问题深度解析
java·leetcode·动态规划
算法_小学生23 分钟前
LeetCode 热题 100(分享最简单易懂的Python代码!)
python·算法·leetcode
执着25923 分钟前
力扣hot100 - 234、回文链表
算法·leetcode·链表
Gorgous—l25 分钟前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法