[LeetCode-Python版]相向双指针——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

思路

把因为示例上的答案是从小到大排列的,因此要考虑去重。在统计合法三元组 (a,b,c) 的个数时,不能把 (c,b,a) 这样的三元组也统计进去

三角形性质:两边之和大于第三边

  • a+b>c(此处必然成立的, a+c≥a+b>b(a≥1))
  • a+c>b(也必然成立,因为 b+c≥a+a=2a>a)
  • b+c>a

所以只需要考虑第一个式子,那么问题变成,从 nums 中选三个数,满足 1≤a≤b≤c 且 a+b>c 的方案数。

时空复杂度

时间复杂度: O ( n 2 ) O(n^2) O(n2)

空间复杂度: O ( 1 ) O(1) O(1)

参考代码

python 复制代码
class Solution:
    def triangleNumber(self, nums: List[int]) -> int:
        nums.sort()
        n = 0

        for k in range(2,len(nums)):
            i = 0
            j = k-1

            while i<j:
                if nums[i]+nums[j]> nums[k]:
                    n+= j-i
                    j-=1
                else:
                    i+=1
        return n
        
        
相关推荐
2401_887724507 小时前
CSS如何设置文字溢出显示省略号_利用text-overflowellipsis
jvm·数据库·python
m0_747854527 小时前
golang如何实现应用启动耗时分析_golang应用启动耗时分析实现思路
jvm·数据库·python
雾岛听蓝7 小时前
Qt操作指南:窗口组成与菜单栏
开发语言·经验分享·笔记·qt
解救女汉子7 小时前
如何截断SQL小数位数_使用TRUNCATE函数控制精度
jvm·数据库·python
zopple7 小时前
Laravel vs ThinkPHP:PHP框架终极对决
开发语言·php·laravel
2301_803875618 小时前
如何用 objectStore.get 根据主键 ID 获取数据库单条数据
jvm·数据库·python
松☆8 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
耿雨飞8 小时前
Python 后端开发技术博客专栏 | 第 06 篇 描述符与属性管理 -- 理解 Python 属性访问的底层机制
开发语言·python
weixin_458580128 小时前
如何修改AWR保留时间_将默认8天保留期延长至30天的设置
jvm·数据库·python
耿雨飞8 小时前
Python 后端开发技术博客专栏 | 第 08 篇 上下文管理器与类型系统 -- 资源管理与代码健壮性
开发语言·python