[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 <= numsi <= 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
        
        
相关推荐
荣码6 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
用户83562907805121 小时前
Python 操作 PDF 附件:添加、查看与管理指南
后端·python
宇宙之一粟1 天前
乐企版式文件生成平台
java·后端·python
To_OC2 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
学测绘的小杨2 天前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
zzzzzz3102 天前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐2 天前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
兵慌码乱3 天前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot3 天前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
To_OC3 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode