力扣(LeetCode)611. 有效三角形的个数(Java)

White graces:个人主页

🙉专栏推荐:Java入门知识🙉

🐹今日诗词:雾失楼台,月迷津渡🐹


⛳️点赞 ☀️收藏⭐️关注💬卑微小博主🙏

⛳️点赞 ☀️收藏⭐️关注💬卑微小博主🙏


题目描述

题目链接: 611. 有效三角形的个数

题目分析

正常思路(暴力解法)

遍历所有可能情况, 判断出能够成三角形的情况, 并记录下来

缺点: 复杂度较高, 并且容易超时

双指针算法

三角形: 任意两边之和大于第三边,

如果我们对数组进行排序, 只需要看最小的值大于第三边就可以了

因此我们固定最大值, 移动较小值,

比如2 2 3 4, 固定最大值, 可以构成三个三角形,

那么如何遍历出这三种情况呢?


**我们定义三个指针,**left, right, cur

固定cur指针, 移动左右两个指针

right = 3时有两张情况, 2 3 4(第一个2),2 3 4(第二个2)

此时记录三角形的个数, 个数等于 right - left ,然后继续right--继续遍历

右边指针移动的时机

当符合三角形判断条件移动右指针左移: 也就是左右指针对应元素和大于cur元素

右指针移动的时机

当不符合三角形判断条件移动右指针左移

编写代码

java 复制代码
class Solution {
    public int triangleNumber(int[] nums) {
        Arrays.sort(nums);
        // 记录个数
        int result = 0;

        for (int cur = nums.length - 1; cur >= 2; cur--) {
            int left = 0;
            int right = cur - 1;
            while (left < right) {
                if (nums[left] + nums[right] > nums[cur]) {
                    // 符合三角形判断条件, right--, 继续看还有没有符合的
                    result += right - left;
                    right--;
                } else {
                    // 说明两边和小于第三边, left+1, 加过之后看两边能不能大于第三边
                    left++;
                }
            }
        }
        return result;
    }
}

复杂度分析

美图分享

✨🎆谢谢你的阅读和耐心!祝愿你在编程的道路上取得更多的成功与喜悦!"🎆✨🎄

⭐️点赞收藏加关注,学习知识不迷路⭐️

🎉✔️💪🎉✔️💪🎉✔️💪🎉✔️💪🎉

👍😏⛳️点赞☀️收藏⭐️关注😏👍

👍😏⛳️点赞☀️收藏⭐️关注😏👍

👍😏⛳️点赞☀️收藏⭐️关注😏👍

🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️

相关推荐
熬了夜的程序员2 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
立志成为大牛的小牛3 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
前端小L5 小时前
二分查找专题(九):“降维”的魔术!将二维矩阵“拉平”为一维
数据结构·算法
她说人狗殊途6 小时前
时间复杂度(按增长速度从低到高排序)包括以下几类,用于描述算法执行时间随输入规模 n 增长的变化趋势:
数据结构·算法·排序算法
Miraitowa_cheems6 小时前
LeetCode算法日记 - Day 102: 不相交的线
数据结构·算法·leetcode·深度优先·动态规划
野生技术架构师6 小时前
盘一盘Redis的底层数据结构
数据结构·数据库·redis
Miraitowa_cheems6 小时前
LeetCode算法日记 - Day 101: 最长公共子序列
数据结构·算法·leetcode·深度优先·动态规划
北冥湖畔的燕雀6 小时前
std之list
数据结构·c++·list
南方的狮子先生7 小时前
【C++】C++文件读写
java·开发语言·数据结构·c++·算法·1024程序员节
Alex艾力的IT数字空间7 小时前
完整事务性能瓶颈分析案例:支付系统事务雪崩优化
开发语言·数据结构·数据库·分布式·算法·中间件·php