美文网首页
LeetCode-611-有效三角形的个数

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

作者: 阿凯被注册了 | 来源:发表于2020-11-07 18:19 被阅读0次

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


    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
    

    相关文章

      网友评论

          本文标题:LeetCode-611-有效三角形的个数

          本文链接:https://www.haomeiwen.com/subject/vqrqbktx.html