其他分享
首页 > 其他分享> > LeetCode-611-有效三角形的个数

LeetCode-611-有效三角形的个数

作者:互联网

给定一个包含非负整数的数组,你的任务是统计其中可以组成三角形三条边的三元组个数。


image.png

解题思路:

  1. 最外层i遍历从0至倒数第三位;
  2. 内层j从i+1开始遍历至倒数第二位;
  3. 指针k从i+2开始向后游走,直到不满足三角形条件,此时j到k之间的数均满足条件,累加进count;

Python3代码:

class Solution:
    def triangleNumber(self, nums: List[int]) -> int:
        count = 0
        nums.sort()
        for i in range(len(nums)-2):
            if nums[i] == 0:
                continue
            k = i+2
            for j in range(i+1, len(nums)-1):
                while k < len(nums) and nums[i]+nums[j]>nums[k]:
                    k+=1
                count += k-j-1
        return count
 

标签:count,nums,int,611,个数,len,range,三角形,LeetCode
来源: https://www.cnblogs.com/Maii/p/13941839.html