LeetCode 0611.有效三角形的个数:双指针

【LetMeFly】611.有效三角形的个数:双指针

力扣题目链接:https://leetcode.cn/problems/valid-triangle-number/

给定一个包含非负整数的数组 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

解题方法:双指针

当两短边之和大于长边时,三条边可以组成三角形。

因此我们可以第一层循环枚举最长边(数组排序后从后往前枚举),至于两个短边则使用双指针:

初始时候l = 0, r = i - 1

如果nums[l] + nums[r] > nums[i],则说明l, l + 1, l + ...的任何一个都可以和nums[r]之和大于 n u m s [ i ] nums[i] nums[i],找到了 r − l r-l r−l个三角形;之后r--

否则,l++

内层双指针相当于是在外层三角形最长边确定的情况下,从右往左看看第二长边为 n u m s [ r ] nums[r] nums[r]时有多少个 n u m s [ l ] nums[l] nums[l]可以匹配。如果当前nums[l]无法匹配则右移l直至能匹配上为止,否则就往左枚举下一个第二长边r。

  • 时间复杂度 O ( l e n ( n u m s ) 2 ) O(len(nums)^2) O(len(nums)2)
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
cpp 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-09-26 22:40:03
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-09-26 22:44:19
 */
class Solution {
public:
    int triangleNumber(vector<int>& nums) {
        int ans = 0;
        sort(nums.begin(), nums.end());
        for (int i = nums.size() - 1; i >= 0; i--) {
            for (int l = 0, r = i - 1; l < r;) {
                if (nums[l] + nums[r] > nums[i]) {
                    ans += r - l;
                    r--;
                } else {
                    l++;
                }
            }
        }
        return ans;
    }
};
Python
python 复制代码
'''
Author: LetMeFly
Date: 2025-09-26 22:40:03
LastEditors: LetMeFly.xyz
LastEditTime: 2025-09-26 22:47:15
'''
from typing import List

class Solution:
    def triangleNumber(self, nums: List[int]) -> int:
        ans = 0
        nums.sort()
        for i in range(len(nums) - 1, -1, -1):
            l, r = 0, i - 1
            while l < r:
                if nums[l] + nums[r] > nums[i]:
                    ans += r - l
                    r -= 1
                else:
                    l += 1
        return ans
Python
python 复制代码
'''
Author: LetMeFly
Date: 2025-09-26 22:40:03
LastEditors: LetMeFly.xyz
LastEditTime: 2025-09-26 23:04:01
'''
__import__("atexit").register(lambda: open("display_runtime.txt", "w").write("0"))
from typing import List

class Solution:
    def triangleNumber(self, nums: List[int]) -> int:
        ans = 0
        nums.sort()
        for i in range(len(nums) - 1, -1, -1):
            l, r = 0, i - 1
            while l < r:
                if nums[l] + nums[r] > nums[i]:
                    ans += r - l
                    r -= 1
                else:
                    l += 1
        return ans
Java
java 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-09-26 22:40:03
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-09-26 22:51:26
 */
import java.util.Arrays;

class Solution {
    public int triangleNumber(int[] nums) {
        Arrays.sort(nums);
        int ans = 0;
        for (int i = nums.length - 1; i >= 0; i--) {
            for (int l = 0, r = i - 1; l < r;) {
                if (nums[l] + nums[r] > nums[i]) {
                    ans += r - l;
                    r--;
                } else {
                    l++;
                }
            }
        }
        return ans;
    }
}
Go
go 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-09-26 22:40:03
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-09-26 22:49:15
 */
package main

import "sort"

func triangleNumber(nums []int) (ans int) {
    sort.Ints(nums)
    for i := len(nums) - 1; i >= 0; i-- {
        for l, r := 0, i - 1; l < r; {
            if nums[l] + nums[r] > nums[i] {
                ans += r - l
                r--
            } else {
                l++
            }
        }
    }
    return
}
Rust
rust 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-09-26 22:40:03
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-09-26 23:00:24
 */
impl Solution {
    pub fn triangle_number(mut nums: Vec<i32>) -> i32 {
        nums.sort();
        let mut ans: usize = 0;
        for i in (0..nums.len()).rev() {
            let mut l: usize = 0;
            let mut r: usize = i.saturating_sub(1);  // 防止unsize为-1
            while l < r {
                if nums[l] + nums[r] > nums[i] {
                    ans += r - l;
                    r -= 1;
                } else {
                    l += 1;
                }
            }
        }
        ans as i32
    }
}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
蒙奇D索大20 分钟前
【算法】递归的艺术:从本质思想到递归树,深入剖析算法的性能权衡
经验分享·笔记·算法·改行学it
王哈哈^_^30 分钟前
【数据集+完整源码】水稻病害数据集,yolov8水稻病害检测数据集 6715 张,目标检测水稻识别算法实战训推教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
light_in_hand1 小时前
内存区域划分——垃圾回收
java·jvm·算法
小安同学iter2 小时前
SQL50+Hot100系列(11.7)
java·算法·leetcode·hot100·sql50
_dindong2 小时前
笔试强训:Week-4
数据结构·c++·笔记·学习·算法·哈希算法·散列表
星释2 小时前
Rust 练习册 :Nucleotide Codons与生物信息学
开发语言·算法·rust
寂静山林2 小时前
UVa 1366 Martian Mining
算法
陌路203 小时前
S12 简单排序算法--冒泡 选择 直接插入 希尔排序
数据结构·算法·排序算法
雾岛—听风3 小时前
P1012 [NOIP 1998 提高组] 拼数
算法
papership4 小时前
【入门级-算法-5、数值处理算法:高精度的乘法】
数据结构·算法