leetcode刷题:611.有效三角形的个数(双指针实现)

题目地址:有效三角形的个数


解决此题时,首先需要知道的是如何判断三个数字是否能够构成三角形。

我们知道,三角形任意两边之和都大于第三边。所以判断三个数字是否能构成三角形需要进行三次比较(最基础的思路)

方法一:暴力枚举

此题一个最容易想到的解法就是暴力遍历。即穷举法,列举出每一种可能的组合情况并进行判断。不难想到需要设置三重循环,时间复杂度是O(n^3)。但是这种方法可能会有超时的风险(也许使用C/C++能够侥幸通过,但如果使用python之类较慢的语言大概率无法通过)

方法二:双指针

上述我们已经给出了判断三个数是否构成三角形的方法,然而三次判断其实也比较繁琐,是否可以实现一次判断呢?

其实我们在数学学习中肯定知道一种方法,那就是判断三个数中较小的两个数之和与最大数的大小关系。因为只要最小的数加起来大于最大的数,那么这三个数无论如何组合,最后得到的结果肯定都是满足三角形的性质的。

因此我们就可以采取这样一种思想来设计算法。首先找到最大的数,然后对于剩余的数进行排列组合,判断它们的和是否大于最大的数。

为了找到最大的数,我们可以先将原数组进行升序排序。此时可以知道最大的数就在数组尾端。此时设置双指针,分别指向剩余数组中的最小数与最大数。通过操作双指针进行判断。

如何控制双指针的指向呢?我们可以以下列例子来简单模拟一下:

 

需要注意的是,max至少需要指向第三个元素(下标为2),因为至少需要三条边才能构成一个三角形。

采用双指针方法时间复杂度为O(n^2),相较于暴力解法有很大提升。

class Solution {
public:int triangleNumber(vector<int>& nums) {sort(nums.begin(),nums.end());int ret=0;int n=nums.size();for(int i=n-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.hqwc.cn/news/255095.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法-贪心思想

贪心的思想非常不好解释&#xff0c;而且越使用权威的语言解释越难懂。而且做题的时候根据自己的理解可能直接做出来&#xff0c;但是非要解释一下怎么使用的贪心的话&#xff0c;就懵圈了。一般来说&#xff0c;贪心的题目没有固定的套路&#xff0c;一题一样&#xff0c;不过…

Windows系统的笔记本电脑要怎样做,才能控制iPad?

Windows 10.1803或以上版本并且支持5.0低功耗蓝牙&#xff08;BLE&#xff09;的台式电脑或笔记本电脑都可以通过蓝牙连接控制iPhone或iPad。 控制成功后&#xff0c;你可以在电脑上直接用鼠标操作iPhone或iPad&#xff0c;避免工作学习中频繁抬头低头切换界面&#xff0c;也可…

IMR TBR TBDR

IMR Immediate Mode Rendering(即时渲染)&#xff0c;是 PC 和主机 GPU 使用的渲染方式 IMR下的渲染示意图 每次渲染&#xff0c;都要读写Frame Buffer和Depth Buffer IMR优化 IMR需要大量的带宽和功耗&#xff0c;优化方式是L1、L2 Cache大缓存&#xff0c;不适用于移动G…

HASH 哈希算法之MD5 算法

1. 哈希算法&#xff0c;用C 写的 #include <iostream> #include <iomanip> #include <cstring> #include <openssl/md5.h> #include <stdio.h>using namespace std;int main() {string str "hello world";unsigned char digest[MD5…

谷歌ARCore认证,什么是ARCore认证

一、谷歌ARCore认证介绍 谷歌ARCore 是 Google 推出的用于打造增强现实体验的平台,利用移动设备的传感器以及相机通过不同的 API 让您的手机能够感知其所处环境、了解世界并进行信息交互。设备要使用谷歌的ARCore功能&#xff0c;需要进行测试并通过认证后方可预载或使用Googl…

sqlserver已经启动了允许远程连接,但局域网内无法访问

sqlserver已经启动了允许远程连接&#xff0c;但局域网内无法访问。 可以确认一下sqlserver browser是不是没有启动。 修改启动模式为自动试一试。

基于ssm学校运动会信息管理系统论文

摘 要 在当今社会上&#xff0c;体育运动越来越普及&#xff0c;参与运动会的人越来越多&#xff0c;但是目前对运动会信息管理还是处于手工记录的时代&#xff0c;这远远满足不了现在用户需求&#xff0c;因此建立一个运动会信息管理系统已经变的非常重要。 本文重点阐述了学…

深圳锐杰金融:用金融力量守护社区健康

深圳市锐杰金融投资有限公司&#xff0c;作为中国经济特区的中流砥柱&#xff0c;近年来以其杰出的金融成绩和坚定的社会责任立场引人注目。然而&#xff0c;这并非一个寻常的金融机构。锐杰金融正在用自己的方式诠释企业责任和慈善精神&#xff0c;通过一系列独特的慈善项目&a…

文心一言大模型应用开发入门

本文重点介绍百度智能云平台、文心一言、千帆大模型平台的基本使用与接入流程及其详细步骤。 注册文心一言 请登录文心一言官方网站 https://yiyan.baidu.com/welcome 点击登录&#xff1b;图示如下&#xff1a; 请注册文心一言账号并点击登录&#xff0c;图示如下&#xff1…

高精度加法,减法,乘法,除法(上)(C语言)

前言 加&#xff0c;减&#xff0c;乘&#xff0c;除这些运算我们自然信手捏来&#xff0c;就拿加法来说&#xff0c;我们要用c语言编程算ab的和&#xff0c;只需让sum ab即可&#xff0c;可是这是局限的&#xff0c;我们都知道int的表示的最大值为2147483647&#xff08;32位…

LLM之RAG实战(一):使用Mistral-7b, LangChain, ChromaDB搭建自己的WEB聊天界面

一、RAG介绍 如何使用没有被LLM训练过的数据来提高LLM性能&#xff1f;检索增强生成&#xff08;RAG&#xff09;是未来的发展方向&#xff0c;下面将解释一下它的含义和实际工作原理。 ​ 假设您有自己的数据集&#xff0c;例如来自公司的文本文档。如何让ChatGPT和其他…

【C语言】数据在内存中的存储

目录 练笔 整型数据的存储&#xff1a; char 型数据——最简单的整型 整型提升&#xff1a; 推广到其他整形&#xff1a; 大小端&#xff1a; 浮点型数据的存储&#xff1a; 存储格式&#xff1a; 本篇详细介绍 整型数据&#xff0c;浮点型数据 在计算机中是如何储存的。…