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

双指针算法专题之——有效三角形的个数

文章目录

  • 题目介绍
  • 思路分析
  • AC代码

题目介绍

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

思路分析

如果判断三个数能否构成一个三角形,相信大家都知道:

只要任意两边之和大于第三边即可。
比如三条边长度为a,b,c
那只要满足
a+b>c
a+c>b
b+c>a

但是,这样要判断三个条件,我们来介绍另一种方法:

如果三条边的长短已经知道:a<=b<=c
那么此时只需满足较短的两条边之和大于最长的那条边,即
a+b>c
那么它们就一定能构成一个三角形,另外两个条件就不需要判断了
原理很简单,因为c是最大的,c+一个数一定比另外两条边还大。

那题目呢,是给定一个包含非负整数的数组 nums ,要返回其中可以组成三角形三条边的三元组个数。

所以,判断的时候,我们可以先给数组排个序(升序)

然后呢,我们就可以用双指针来解决这道题,具体怎么做呢?我们来看一个例子:

给这样一个数组

最大值是10,所以我们先让固定c为10
那a,b呢?

一个指向剩余区间的最大值,一个指向最小值
然后判断,此时的a+b=11,当然大于10(第一种情况:a+b>c),所以当前这一组是满足的,可以构成三角形。
然后我们观察,此时a是最小的,所以此时ab之间的数据都是>=a的,所以中间的这些数据和b相加一定都大于此时的c。

一共几种呢,就是b的下标-c的下标

当前情况下就是5-0=5种。
所以中间的情况就不用判断了。b=9时一共5种情况可行。
假设两个指针left和right分别指向ab,那接下来只需让right--即可,判断c=10,b=5时候的情况

此时a+b<c(第二种情况:a+b<=c
所以构不成三角形,并且,可以断定此时a和ab之间的数都相加都不大于c,因为这些数都比此时的b(5)小

所以固定c为10的情况下,a=2时,跟2 3 4 5都不行(9已经判断过了)
所以此时让left++,看后面的行不行(后面的数一定>=2,因为已经排序)
后序也是如此进行判断。
这一轮结束后(当left>=right结束),固定c为10的情况就计算完了,只需让c指向9,right从c的前面开始,left还从0下标开始,进重复上述操作,行下一轮的判断即可。

总结一下:

  1. 先固定c为最大的数
  2. 定义双指针,按照上述逻辑,判断出当前情况下符合条件的三元组个数。
    如果a+b>c,b前面的元素个数就是b为当前值的情况下符合条件的三元组个数,然后b往前移(right- -);
    如果a+b<=c,说明a为当前值的情况下找不到满足条件的,让a往后移(left++),再重新判断
  3. 固定c为次大的数,重复上述操作,当c前面的数小于2个,就结束了(即c的下标<2)

AC代码


classSolution{public:inttriangleNumber(vector<int>&nums){sort(nums.begin(),nums.end());intindex_c=nums.size()-1;//c的下标intcount=0;while(index_c>=2)//index_c<2,此时左边的数就不够两个了{intleft=0;//标识a的位置intright=index_c-1;//b的位置while(left<right){if((nums[left]+nums[right])>nums[index_c]){count+=(right-left);--right;}else++left;}--index_c;}returncount;}};
http://www.jsqmd.com/news/670014/

相关文章:

  • Z-Image-Turbo-rinaiqiao-huiyewunv惊艳效果:校服褶皱/领结反光/瞳孔高光细节特写
  • 5分钟掌握NetPad CLI:从脚本运行到系统管理的终极指南
  • uBlock-Origin-dev-filter数据清理原理:DNS检测与SEO垃圾网站识别
  • 如何高效下载抖音内容:douyin-downloader的完整使用指南
  • button-card JavaScript模板实战:动态内容与条件渲染的终极教程
  • Qwen-Image-2512+Pixel Art LoRA应用案例:为开源像素字体项目生成字形图
  • 从STM32到51单片机:一个Keil MDK搞定双平台开发的保姆级环境配置指南
  • opencv-rust性能优化:让你的计算机视觉应用运行更高效
  • TimeCat开源社区指南:如何参与项目讨论和贡献
  • SnapRAID奇偶校验深度解析:理解6级保护机制
  • OFA-VE视觉蕴含分析系统入门必看:从零部署到精准判断YES/NO/MAYBE
  • Azure Linux监控指标终极指南:零基础开发自定义Prometheus Exporter
  • HTTPoison与JSON处理:如何高效集成Jason库进行数据序列化
  • Nanotron多节点训练实战:从Slurm配置到大规模部署
  • 题解:洛谷 AT_abc358_d [ABC358D] Souvenirs
  • 全面掌握Path of Building:流放之路Build规划终极解决方案
  • Intv_AI_MK11 助力技术写作:使用Typora配合AI进行Markdown文档高效创作
  • 前端开发资源宝库gh_mirrors/fr/frontend-development:1000+免费与付费资源完全指南
  • 百灵快传(B0Pass)性能优化技巧:如何提升大文件传输速度与并发处理能力
  • 题解:AcWing 11 背包问题求方案数
  • 手机号码定位查询系统:3步快速获取地理位置信息
  • eslint-plugin-security常见问题解决方案:从安装到配置的全方位排错
  • 终极指南:如何使用GRequests构建高性能REST API客户端
  • 如何参与rms-support-letter.github.io签名:3种简单方法完整指南
  • mStream多平台部署实战:Docker、树莓派、云服务器完整教程
  • I2C SPI 画图 工具 程序合集
  • 终极xplr快捷键清单:2024最全默认键盘绑定速查手册
  • 7天掌握Flutter测试驱动开发:从入门到实战的完整指南
  • Azure Linux内存管理终极指南:10个透明大页与内存压缩技术优化技巧
  • 一级减速器正文、零件图、装配图、说明书