LeetCode 611.有效三角形的个数

给定一个包含非负整数的数组 nums ,返回其中可以组成三角形三条边的三元组个数。

示例 1:

输入: nums = [2,2,3,4]

输出: 3

解释:有效的组合是:

2,3,4 (使用第一个 2)

2,3,4 (使用第二个 2)

2,2,3

示例 2:

输入: nums = [4,2,3,4]

输出: 4

提示:

1 <= nums.length <= 1000

0 <= nums[i] <= 1000

先对nums进行排序,然后固定最短边,进行同向双指针:

cpp 复制代码
class Solution {
public:
    int triangleNumber(vector<int>& nums) {
        if (nums.size() < 3) {
            return 0;
        }

        sort(nums.begin(), nums.end());

        int ans = 0;

        for (int i = 0; i < nums.size() - 2; ++i) {
            int left = i + 1;
            int right = i + 2;

            while (right < nums.size()) {
                // 当两短边之和大于长边时
                // 中边取[left, right - 1]之间的所有值都可以组成有效三角形
                if (left == right || nums[i] + nums[left] > nums[right]) {
                    ans += right - left;
                    ++right;
                } else {
                    ++left;
                }
            }
        }

        return ans;
    }
};

如果nums的长度为n,则此算法时间复杂度为O(n2^22),空间复杂度为O(logn)。

相关推荐
MediaTea9 小时前
Python 库手册:gc 垃圾回收
java·开发语言·jvm·python·算法
QxQ么么15 小时前
移远通信(桂林)26校招-助理AI算法工程师-面试纪录
人工智能·python·算法·面试
Mz122117 小时前
day05 移动零、盛水最多的容器、三数之和
数据结构·算法·leetcode
SoleMotive.17 小时前
如果用户反映页面跳转得非常慢,该如何排查
jvm·数据库·redis·算法·缓存
念越17 小时前
判断两棵二叉树是否相同(力扣)
算法·leetcode·入门
未可知77718 小时前
软件设计师(上午题4)、面向对象、uml、设计模式
设计模式·职场和发展·uml
ghie909019 小时前
线性三角波连续调频毫米波雷达目标识别
人工智能·算法·计算机视觉
却话巴山夜雨时i19 小时前
74. 搜索二维矩阵【中等】
数据结构·算法·矩阵
sin_hielo19 小时前
leetcode 3512
数据结构·算法·leetcode