【OJ刷题】双指针问题4

这里是阿川的博客,祝您变得更强 ✨ 个人主页:在线OJ的阿川

💖文章专栏:OJ刷题入门到进阶
🌏代码仓库:


写在开头

现在您看到的是我的结论或想法但在这背后凝结了大量的思考、经验和讨论


目录

  • [1. 题目介绍](#1. 题目介绍)
  • [2. 题目拆解](#2. 题目拆解)
  • [3. 具体详情](#3. 具体详情)
  • [4. 具体代码](#4. 具体代码)

1. 题目介绍

难度:中
题目练习有效三角形的个数
题目信息 :给定一个包含非负整数的数组 nums ,返回其中可以组成三角形三条边的三元组个数。
举个例子: 具体如图1所示

图1 举个例子


2. 题目拆解

本质上:观察规律,利用单调性
特点是:在组合搭配中有一定单调性规律
解决方法:双指针算法,如图2所示

图2 双指针


3. 具体详情

1. 先进行排序
2. 固定其中最大的数,再将最小和第二大数作为双指针对最大数进行比较
3. 两种情况:

  • 最小和第二大数之和大于最大数,则中间数与第二大数组合均符合要求,再将第二大树数移动减小
  • 最小和第二大数之和小于或等于最大数,则中间数与最小数组合均不符合要求,再将最小数移动增大

4. 最后再将最大数移动减小,直至遍历完整个数组


4. 具体代码

cpp 复制代码
class Solution {
public:
    int triangleNumber(vector<int>& nums)
    {
        // 进行排序
        sort(nums.begin(), nums.end());
        int sum = 0, 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])
                {
                    sum += right - left;
                    right--;
                }
                else
                {
                    left++;
                }
            }
        }
        return sum;

    }
};
  1. 夹带私货

若你能看到看到这篇文章且能看到这 ,则说明你我有缘留个关注吧 ,后面还会接着计算机408、底层原理、开源项目、以及数据、后端研发相关、实习、笔试/面试、秋招/春招、各种竞赛相关、简历相关、考研、学术相关......,祝你我变得更强


好的,到此为止啦,祝您变得更强

道阻且长 行则将至
个人主页:在线OJ的阿川大佬的支持和鼓励,将是我成长路上最大的动力
相关推荐
ShineWinsu21 分钟前
对于Linux:内核是如何组织管理IPC资源的解析
linux·服务器·c++·面试·笔试·线程·ipc
少司府42 分钟前
C++进阶:红黑树
开发语言·数据结构·c++·b树·二叉树·红黑树
工业胶粘剂技术1 小时前
单组分高温环氧结构胶 K-EP280 完整技术参数与工程选型分析
算法·制造
汉克老师1 小时前
GESP6级C++考试语法知识(五十五、动态规划----背包问题(八、混合背包)
c++·动态规划·dp·背包问题·gesp六级·混合背包问题
特种加菲猫1 小时前
哈希表的实现
开发语言·c++
学机械的鱼鱼1 小时前
一文读懂轮足翼复合机器人:结构特点与仿真学习路线规划
学习·机器人
玖釉-1 小时前
nvpro_core2 详解:NVIDIA Vulkan / OpenGL 图形样例背后的现代 C++ 基础库
c++·windows·图形渲染
不会C语言的男孩1 小时前
C++ Primer 第19章:特殊工具与技术
数据结构·c++
知识分享小能手1 小时前
Hadoop学习教程,从入门到精通, 部署Hadoop 3.x — 知识点详解(2)
大数据·hadoop·学习
不会C语言的男孩1 小时前
C++ Primer 第18章:用于大型程序的工具
开发语言·c++