【优选算法】5----有效三角形个数

又是一篇算法题,今天早上刚做的热乎的~

其实我是想写博客但不知道写些什么(就水一下啦)

-------------------------------------begin-----------------------------------------

题目解析:

这道题的题目算是最近几道算法题里面题目最短的,但是单单看题目的话,我就只知道有一个数

组,需要我们去返回其中符合三角形特性的三条边,所以我们可以从示例入手,了解这道算法需要

我们去实现的地方~

讲解算法原理:

先说暴力解法吧,我们就需要用到三个for循环来进行遍历,时间复杂度为O(n^3),在力扣上面肯

定是编译不过的,所以在这个基础上,我们需要优化算法~

新思路:我们可以将所给数组先进行排序,排序成单调递增的数组,两个指针left和right,left指

针从位置0向右遍历,right从n-1位置向左遍历,分两种情况,两指针所指数的和大于位置i的值和

小于位置i的值,再定义一个ret变量,用于储存有效三角形的个数~

编写代码:

cpp 复制代码
class Solution 
{
public:
    int triangleNumber(vector<int>& nums)  
    {
        sort(nums.begin(), nums.end());
        int ret = 0, n = nums.size();
        for(int i=n-1;i>=2;i--)
        {
            int left=0,right=i-1;
            while(left<right)
            {
                if(nums[left]+nums[right]>nums[i])
                {
                    ret+=right-left;
                    right--;
                }
                else
                {
                    left++;
                }
            }
        }
        return ret;
    }
};

差不多就是这个样子啦~

题目链接直达->

611. 有效三角形的个数 - 力扣(LeetCode)

----------------------------------------end----------------------------------------

相关推荐
轻语呢喃12 分钟前
每日LeetCode : 两数相加--链表操作与进位的经典处理
javascript·算法
钢铁男儿20 分钟前
C# 接口(接口可以继承接口)
java·算法·c#
lhxcc_fly21 分钟前
mmap映射文件
c++·地址映射文件·!fd
zl_vslam1 小时前
SLAM中的非线性优化-2D图优化之激光SLAM cartographer前端匹配(十七)
前端·人工智能·算法
dying_man2 小时前
LeetCode--44.通配符匹配
算法·leetcode
Paper Clouds2 小时前
代码随想录|图论|15并查集理论基础
数据结构·算法·leetcode·深度优先·图论
Paper Clouds2 小时前
代码随想录|图论|14有向图的完全可达性
数据结构·算法·深度优先·图论·宽度优先
有冠希没关系3 小时前
Ffmpeg滤镜
c++
遇见尚硅谷3 小时前
C语言:游戏代码分享
c语言·开发语言·算法·游戏
不喜欢学数学er3 小时前
第二十八天:贪心算法part02(第八章)
算法·贪心算法