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

有效三角形个数问题

目录

一·题目简述:

二·思路总结:

2·1不被认可的暴力破解思路:

2·2优化后的思路:

2·2·1优化后的判断三角形方法:

2·2·2 定一动二指针朝内筛选遍历: 

三·解答代码:


一·题目简述:

leetcode链接:. - 力扣(LeetCode) 

二·思路总结:

2·1不被认可的暴力破解思路:

想必大家看到这道题首先一定想的就是三次循环嵌套,然后再加上判断三角形(任意两边都大于第三步)来完成此操作。伪代码:

for (int i = 0; i < nums.size()-2; i++) {for (int j = i + 1; j < nums.size() - 1; j++){for (int k = j + 1; k < nums.size(); k++) {check_triangle(nums[i], nums[j],nums[k])//判断是否为三角形}}
}

然而这种复杂度直接到了o(n^3);因此要换一种思路。

2·2优化后的思路:

2·2·1优化后的判断三角形方法:

想必正常都是 要么任意两边都大于第三步,要么两边差小第三边,两边和大第三边。

但是这种就是新的方法:如果我们把这组数据排好序,拿到最大的数,然后让比它小两个数之和跟它比较,便可以一步得出:

2·2·2 定一动二指针朝内筛选遍历: 

思路:固定最大值+双指针筛选朝里遍历:
为了减少判断三角形(任意两边都大于第三边),升级版:首先让数组内值有序,然后只需要判断另两个值是否大于最大值即可,如果大于
就是符合,否则不符合,然后固定数前面的,
如果大于:最小值前面的与它组合都会大于,故right--(此时right这个位置的数已完成了此次任务)
如果小于:则最小值加上此值前面比它小的值,然后都比它小故left++

下面画图展示一下:

  

 此时时间复杂度直接从o(n^3)变成了o(n^2)。

三·解答代码:

class Solution {
public:int triangleNumber(vector<int>& nums) {sort(nums.begin(),nums.end(),less<int>());//按升序,方便减少判断三角形时的比较操作int ret=0;//统计个数for(int i=nums.size()-1;i>=2;i--){//固定的最大值从右往左走int left=0,right=i-1;while(left<right){if(nums[left]+nums[right]>nums[i]) ret+=right-left,right--;//符合三角形条件else left++;}}return ret;}
};


http://www.mrgr.cn/news/9869.html

相关文章:

  • 【蓝桥杯集训100题】scratch游泳时长 蓝桥杯scratch比赛专项预测编程题 集训模拟练习题第27题
  • Layer-refined Graph Convolutional Networks for Recommendation【ICDE2023】
  • java 从ftp服务器上传下载删除文件
  • MessageDialog 是 Qt Quick Controls 中的一个组件,用于显示消息对话框
  • DocuSign客户故事 | iCIMS 通过 DocuSign CLM 和 AI 提高销售和法律的团队的签约速度
  • 【涂色 —— 区间dp】
  • nginx知识补充
  • wpf DynamicResource的ResourceKey值进行绑定
  • 基于x86 平台opencv的图像采集和seetaface6的图像质量评估功能
  • python使用ffmpeg将视频、音频合并合成(速度最快)
  • 使用 Springdoc OpenAPI 为 Spring Boot 应用程序生成 Swagger文档
  • AI图片生成网站Midjourney网页版开放注册 每用户可免费生成25张图片
  • 考试:计算机网络(01)
  • 【碎片】FastAPI 路径参数
  • Gazebo Harmonic 和 ROS2 jazzy 安装和测试
  • 备战秋招60天算法挑战,Day24
  • 开放式耳机危害大吗?6点如何挑选合适的开放式耳机!
  • 嵌入式面经篇十——驱动开发
  • 【hot100篇-python刷题记录】【搜索二维矩阵】
  • [JAVA]什么是泛型?泛型在Java中的应用