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)。

相关推荐
疯狂的喵20 小时前
C++编译期多态实现
开发语言·c++·算法
scx2013100420 小时前
20260129LCA总结
算法·深度优先·图论
2301_7657031420 小时前
C++中的协程编程
开发语言·c++·算法
m0_7487080520 小时前
实时数据压缩库
开发语言·c++·算法
小魏每天都学习20 小时前
【算法——c/c++]
c语言·c++·算法
智码未来学堂21 小时前
探秘 C 语言算法之枚举:解锁解题新思路
c语言·数据结构·算法
Halo_tjn21 小时前
基于封装的专项 知识点
java·前端·python·算法
春日见21 小时前
如何避免代码冲突,拉取分支
linux·人工智能·算法·机器学习·自动驾驶
副露のmagic21 小时前
更弱智的算法学习 day59
算法
u0109272711 天前
C++中的RAII技术深入
开发语言·c++·算法