有效三角形个数问题
有效三角形个数问题
一·题目简述:leetcode链接:. - 力扣(LeetCode) 二·思路总结:2·1不被认可的暴力思路:想必大家看到这道题首先一定想的就是三次循环嵌套,然后再加上判断三角形(任意两边都大于第三步)来完成此操作。伪代码:代码语言:javascript代码运行次数:0运行复制for (int i = 0; i < nums.size()-2; i++) {
有效三角形个数问题
leetcode链接:. - 力扣(LeetCode)
想必大家看到这道题首先一定想的就是三次循环嵌套,然后再加上判断三角形(任意两边都大于第三步)来完成此操作。伪代码:
代码语言:javascript代码运行次数:0运行复制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^);因此要换一种思路。
想必正常都是 要么任意两边都大于第三步,要么两边差小第三边,两边和大第三边。
但是这种就是新的方法:如果我们把这组数据排好序,拿到最大的数,然后让比它小两个数之和跟它比较,便可以一步得出:
思路:固定最大值+双指针筛选朝里遍历:
为了减少判断三角形(任意两边都大于第三边),升级版:首先让数组内值有序,然后只需要判断另两个值是否大于最大值即可,如果大于
就是符合,否则不符合,然后固定数前面的,
如果大于:最小值前面的与它组合都会大于,故right--(此时right这个位置的数已完成了此次任务)
如果小于:则最小值加上此值前面比它小的值,然后都比它小故left++
下面画图展示一下:
此时时间复杂度直接从o(n^)变成了o(n^2)。
class Solution {
public:
int triangleumber(vector<int>& nums) {
sort(nums.begin(),(),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;
}
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-01-2,如有侵权请联系 cloudcommunity@tencent 删除优化指针int遍历统计 #感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格
上传时间: 2025-07-18 19:41:40
推荐阅读
留言与评论(共有 10 条评论) |
本站网友 彭氏兄弟 | 1分钟前 发表 |
然后再加上判断三角形(任意两边都大于第三步)来完成此操作 | |
本站网友 深圳最好的婚纱摄影 | 24分钟前 发表 |
方便减少判断三角形时的比较操作 int ret=0;//统计个数 for(int i=nums.size()-1;i>=2;i--){//固定的最大值从右往左走 int left=0 | |
本站网友 浩吉铁路 | 0秒前 发表 |
int triangleumber(vector<int>& nums) { sort(nums.begin() | |
本站网友 泉港租房 | 22分钟前 发表 |
便可以一步得出:2·2·2 定一动二指针朝内筛选遍历: 代码语言:javascript代码运行次数:0运行复制思路:固定最大值+双指针筛选朝里遍历: 为了减少判断三角形(任意两边都大于第三边) | |
本站网友 柴胡舒肝丸说明书 | 20分钟前 发表 |
方便减少判断三角形时的比较操作 int ret=0;//统计个数 for(int i=nums.size()-1;i>=2;i--){//固定的最大值从右往左走 int left=0 | |
本站网友 怎么样除皱 | 8分钟前 发表 |
nums[k])//判断是否为三角形 } } }然而这种复杂度直接到了o(n^);因此要换一种思路 | |
本站网友 大便 | 2分钟前 发表 |
然后都比它小故left++下面画图展示一下: 此时时间复杂度直接从o(n^)变成了o(n^2) | |
本站网友 美的电热水器 | 6分钟前 发表 |
否则不符合 | |
本站网友 伦敦雾霾 | 10分钟前 发表 |
然后都比它小故left++下面画图展示一下: 此时时间复杂度直接从o(n^)变成了o(n^2) |