【双指针_有效三角形的个数_C++】

题目解析

有效三角形的个数

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

需要重复计算:

知识点

1、需要判断三次:

2、只需要判断一次

复制代码
已经知道这三个数的大小(先进行排序)
只需要判断
较小的两个数之和 是否 大于最大的数
就可以得出是否可以构成三角形

算法原理

1、先对整个数组进行排序

2、再去固定最大的数

3、在最大的数的左边区间内使用双指针 算法进行统计符合条件的三元组的个数

编写代码

cpp 复制代码
class Solution {
public:
    int triangleNumber(vector<int>& nums) {
        // 1、排序(从小到大)
        sort(nums.begin(),nums.end());
        // 2、去固定最大的数
        int i = 0;
        int n = nums.size();
        int sum = 0;

        for(i=n-1;i>=2;i--){
        // 3、right每次是从i-1开始(left从0开始)
            int left = 0;
            int right = i-1;

            while(left<right){
                if(nums[left]+nums[right]>nums[i]){
                    sum+=right-left;
                    right--;
                }else{
                    left++;
                }
            }
        }
        return sum;
    }
};
相关推荐
Bella的成长园地4 小时前
面试中关于 c++ async 的高频面试问题有哪些?
c++·面试
彷徨而立4 小时前
【C/C++】什么是 运行时库?运行时库 /MT 和 /MD 的区别?
c语言·c++
qq_417129254 小时前
C++中的桥接模式变体
开发语言·c++·算法
No0d1es6 小时前
电子学会青少年软件编程(C语言)等级考试试卷(三级)2025年12月
c语言·c++·青少年编程·电子学会·三级
bjxiaxueliang7 小时前
一文掌握C/C++命名规范:风格、规则与实践详解
c语言·开发语言·c++
xu_yule8 小时前
网络和Linux网络-13(高级IO+多路转接)五种IO模型+select编程
linux·网络·c++·select·i/o
2301_765703148 小时前
C++与自动驾驶系统
开发语言·c++·算法
轩情吖8 小时前
Qt的窗口(三)
c++·qt
热爱编程的小刘9 小时前
Lesson04---类与对象(下篇)
开发语言·c++·算法
郝学胜-神的一滴9 小时前
Linux网络编程之listen函数:深入解析与应用实践
linux·服务器·开发语言·网络·c++·程序人生