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

相关推荐
CoderCodingNo3 分钟前
【GESP】C++五级/四级练习(双指针/数学) luogu-P1147 连续自然数和
开发语言·c++·算法
颜酱6 分钟前
前端算法必备:双指针从入门到很熟练(快慢指针+相向指针+滑动窗口)
前端·后端·算法
Wect9 分钟前
LeetCode 274. H 指数:两种高效解法全解析
算法·typescript
Q741_14710 分钟前
海致星图招聘 数据库内核研发实习生 一轮笔试 总结复盘(2) 作答语言:C/C++ 哈夫曼编码 LRU
c语言·数据库·c++·算法·笔试·哈夫曼编码·哈夫曼树
Hello.Reader17 分钟前
PyFlink DataStream Operators 算子分类、函数写法、类型系统、链路优化(Chaining)与工程化踩坑
前端·python·算法
hweiyu0018 分钟前
最短路径算法:Floyd-Warshall算法
算法
荒诞硬汉22 分钟前
数组常见算法
java·数据结构·算法
少许极端23 分钟前
算法奇妙屋(二十四)-二维费用的背包问题、似包非包问题、卡特兰数问题(动态规划)
算法·动态规划·卡特兰数·二维费用背包·似包非包
Z1Jxxx27 分钟前
日期日期日期
开发语言·c++·算法
万行33 分钟前
机器学习&第五章生成式生成器
人工智能·python·算法·机器学习