当前位置: 首页 > article >正文

力扣(LeetCode)611. 有效三角形的个数(Java)

White graces:个人主页

🙉专栏推荐:Java入门知识🙉

🐹今日诗词:雾失楼台,月迷津渡🐹


⛳️点赞 ☀️收藏⭐️关注💬卑微小博主🙏

⛳️点赞 ☀️收藏⭐️关注💬卑微小博主🙏


题目描述

题目链接: 611. 有效三角形的个数

题目分析

正常思路(暴力解法)

遍历所有可能情况, 判断出能够成三角形的情况, 并记录下来

缺点: 复杂度较高, 并且容易超时

双指针算法

三角形: 任意两边之和大于第三边,

如果我们对数组进行排序, 只需要看最小的值大于第三边就可以了

因此我们固定最大值, 移动较小值

比如2   2   3    4, 固定最大值, 可以构成三个三角形,

那么如何遍历出这三种情况呢?

我们定义三个指针, left, right, cur

固定cur指针, 移动左右两个指针

right = 3时有两张情况, 2 3 4(第一个2),2 3 4(第二个2)

此时记录三角形的个数, 个数等于  right - left ,然后继续right--继续遍历

右边指针移动的时机

符合三角形判断条件移动右指针左移: 也就是左右指针对应元素和大于cur元素

右指针移动的时机

不符合三角形判断条件移动右指针左移

编写代码

class Solution {
    public int triangleNumber(int[] nums) {
        Arrays.sort(nums);
        // 记录个数
        int result = 0;

        for (int cur = nums.length - 1; cur >= 2; cur--) {
            int left = 0;
            int right = cur - 1;
            while (left < right) {
                if (nums[left] + nums[right] > nums[cur]) {
                    // 符合三角形判断条件, right--, 继续看还有没有符合的
                    result += right - left;
                    right--;
                } else {
                    // 说明两边和小于第三边, left+1, 加过之后看两边能不能大于第三边
                    left++;
                }
            }
        }
        return result;
    }
}

复杂度分析

美图分享

✨🎆谢谢你的阅读和耐心!祝愿你在编程的道路上取得更多的成功与喜悦!"🎆✨🎄

⭐️点赞收藏加关注,学习知识不迷路⭐️

🎉✔️💪🎉✔️💪🎉✔️💪🎉✔️💪🎉

👍😏⛳️点赞☀️收藏⭐️关注😏👍

👍😏⛳️点赞☀️收藏⭐️关注😏👍

👍😏⛳️点赞☀️收藏⭐️关注😏👍

🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️🙆‍♂️


http://www.kler.cn/a/392567.html

相关文章:

  • Golang | Leetcode Golang题解之第559题N叉树的最大深度
  • 【嵌入式开发】单片机CAN配置详解
  • (干货)Jenkins使用kubernetes插件连接k8s的认证方式
  • Pycharm PyQt5 环境搭建创建第一个Hello程序
  • 用vscode编写verilog时,如何有信号定义提示、信号定义跳转(go to definition)、模块跳转这些功能
  • 计算机毕业设计Python+Neo4j知识图谱医疗问答系统 大模型 机器学习 深度学习 人工智能 大数据毕业设计 Python爬虫 Python毕业设计
  • adworld - stack2
  • 基于 Express+JWT + Vue 的前后端分离架构
  • 黄色校正电容102j100
  • 树莓派(Raspberry Pi)Pico 2 C_C++开发环境配置(Docker+SDK)
  • SpringBoot后端解决跨域问题
  • 【Jenkins实战】Windows安装服务启动失败
  • [HAOI2015] 树上染色(树形 DP)
  • 项目技术栈-解决方案-消息队列
  • T507 buildroot linux4.9之AP6275S wifi/bt 以太网开发调试
  • 小白docker入门简介
  • day60 图论章节刷题Part10(Floyd 算法、A * 算法)
  • linq语句在CAD c# 二次开发中的应用——快速筛选curve中polyline
  • 【C++】C++11特性(上)
  • docker执行java的jar包
  • 机器学习引领流体动力学新纪元:CFD、Fluent与OpenFOAM的深度融合
  • ‌STM32的USART2_RX引脚可以外接5V电压
  • 前端js用canvas合成图片并转file对象
  • WebRTC视频 03 - 视频采集类 VideoCaptureDS 上篇
  • openresty入门教程:rewrite_by_lua_block
  • Linux应用——线程池