力扣(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;
    }
}

复杂度分析

美图分享

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

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

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

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

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

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

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

相关推荐
Fanxt_Ja2 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
今后1233 天前
【数据结构】二叉树的概念
数据结构·二叉树
散1123 天前
01数据结构-01背包问题
数据结构
消失的旧时光-19433 天前
Kotlinx.serialization 使用讲解
android·数据结构·android jetpack
Gu_shiwww3 天前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
苏小瀚3 天前
[数据结构] 排序
数据结构
睡不醒的kun3 天前
leetcode算法刷题的第三十四天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
吃着火锅x唱着歌3 天前
LeetCode 978.最长湍流子数组
数据结构·算法·leetcode
Whisper_long3 天前
【数据结构】深入理解堆:概念、应用与实现
数据结构
IAtlantiscsdn3 天前
Redis7底层数据结构解析
前端·数据结构·bootstrap