双指针-【3,4,5,6,7,8】

news2024/11/16 12:56:52

第三题:快乐数

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/happy-number/算法思想:

1.每个节点的值是唯一的(因为会形成环),所以用节点的值充当指针。

2.快指针走两步,慢指针走一步,下次相遇时在环内。

3.如果是快乐数,则环中的数字全是1,否则都不是1(因为1的下一个就是1),直接判定相遇时节点的值即可。

4.一定会形成环,这里就不证明了,因为题目条件给了。(就算不给,也是一定成环的)。

代码实现:

class Solution {
public:
    int next(int n) {
        int res=0;
        while(n) {
            res+=(n%10)*(n%10);
            n/=10;
        }
        return res;
    }
    bool isHappy(int n) {
        int slow=n,fast=n;
        do {
            fast=next(fast);fast=next(fast);
            slow=next(slow);
        }while(fast!=slow);
        if(fast==1) return true;
        return false;
    }
};

第四题:盛水最多的容器

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/container-with-most-water/

算法思想:

V = Height* Width(Height取较小的那一个)

取两头,对于当中较短的边,这已经是最好的情况了(此时宽度取最大(区间长度),高度也取最大(自己本身)),将其计入后就不用再考虑了。现在区间缩小了。

如此循环下去,区间比1小时(l>=r)即可退出。

代码实现:

class Solution {
public:
    int maxArea(vector<int>& height) {
        int l=0,r=height.size()-1,res=0;
        while(l<r) {
            int NewRes=min(height[l],height[r])*(r-l);
            if(NewRes>res) res=NewRes;
            if(height[l]>height[r]) --r;
            else ++l;
        }
        return res;
    }
};

第五题:有效三角形之和

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/valid-triangle-number/算法思想:

1.排序,使数组单调递增。

2.固定最大的数(下标最小是2,否则凑不到三个数),然后从该数组左边的区间取剩下的两个数字。

3.取小区间的两头(一个最小(l),一个最大(r))

如果这两个数足够大(max太大了,min都能带动,其他的更能带的动),res+=r-l;   --r;(r已经计算完了)

如果这两个数不够大(min太小了,max都带不动),++l;( l 太小了,没有利用价值了)

当l与r相遇时,这个大数就计算完了

4.计算下一个大数,一直循环到最后一个

代码实现:

class Solution {
public:
    int triangleNumber(vector<int>& nums) {
        sort(nums.begin(),nums.end());
        int res=0,size=nums.size();
        for(int i=2;i<size;++i) {
            int l=0,r=i-1;
            while(l<r) {
                if(nums[l]+nums[r]>nums[i]) {
                    res+=r-l; --r; 
                }
                else ++l;
            }
        }
        return res;
    }
};

第六题:两数之和

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/he-wei-sde-liang-ge-shu-zi-lcof/算法思想:

取区间的两头(一个最小(l),一个最大(r))

如果这两个数大了(max太大了,带上最小的数还是超过了target,所以min无用) --r;

如果这两个数小了(min太小了,带上了最大的数都够不到target,所以max无用)++l;

如果相等就找到了,走人!

每一次行动都会让区间宽度减1,如果减没了(也就是两指针相遇)还没找到,那就是没有了。

class Solution {
public:
    vector<int> twoSum(vector<int>& price, int target) {
        int l=0,r=price.size()-1;
        while(l<r)
        {
            if(price[l]+price[r]==target) return {price[l],price[r]};
            else if(price[l]+price[r]>target) --r;
            else ++l;
        }
        return {};
    }
};

第七题:三数之和

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/3sum/算法思想:

排序+双指针

注意:去重

1.固定一个数,然后在他右边(因为本思路左边的数都计完了)的区间利用双指针解决两数之和问题。

运行双指针时去重:

对于l:如果加加完了,数值不变,则继续加加,一直到数值变化

对于r:如果减减完了,数值不变,则接着减减,一直到数值变化

2.固定第一个,在固定下一个,将数组遍历一遍。

遍历时去重:如果加加完了,数值不变,则继续加加,一直到数值变化

在连续加加减减时,要注意越界问题。

解决方案:在连续加加减减时,每变化一次,判定一次

代码实现:

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        sort(nums.begin(),nums.end());
        vector<vector<int>> res;
        int size=nums.size();
        for(int i=0;i<size;) {
            if(nums[i]>0) break;
            int j=i+1,k=size-1;
            while(j<k) {
                if(nums[i] +nums[j]+nums[k]>0) --k;
                else if(nums[i]+nums[j]+nums[k]<0) ++j;
                else {
                    res.push_back({nums[i],nums[j],nums[k]});
                    ++j; --k;
                    while(j<k&&nums[j-1]==nums[j]) ++j;
                    while(j<k&&nums[k]==nums[k+1]) --k;
                }
            }
            ++i;
            while(i<size-2&&nums[i]==nums[i-1]) ++i;
        }
        return res;
    }
};

第八题:四数之和

算法思想:

排序+双指针

注意:去重

1.从左到右轮流固定每一个数,然后在他右边的区间利用双指针解决三数之和问题。

2.去重问题和三数之和类似,此处略。

代码实现:

class Solution {
public:
    vector<vector<int>> fourSum(vector<int>& nums, int target) {
        sort(nums.begin(),nums.end());
        vector<vector<int>> res;
        int size = nums.size();
        for(int i=0;i<size-3;) {
            for(int j=i+1;j<size-2;) {
                int k=j+1,r=size-1;
                while(k<r) {
                    if((long)nums[i]+nums[j]+nums[k]+nums[r]<target) ++k;
                    else if((long)nums[i]+nums[j]+nums[k]+nums[r]>target) --r;
                    else if((long)nums[i]+nums[j]+nums[k]+nums[r]==target) {
                        res.push_back({nums[i],nums[j],nums[k],nums[r]});
                        ++k; --r;
                        while(k<r&&nums[k]==nums[k-1]) ++k;
                        while(k<r&&nums[r]==nums[r+1]) --r;
                    }
                }
                ++j;
                while(j<size-2&&nums[j]==nums[j-1]) ++j;
            }
            ++i;
            while(i<size-3&&nums[i]==nums[i-1]) ++i;
        }
        return res;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1960889.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

jdk版本管理利器-sdkman

1.什么是sdkman&#xff1f; sdkman是一个轻量级、支持多平台的开源开发工具管理器&#xff0c;可以通过它安装任意主流发行版本&#xff08;例如OpenJDK、Kona、GraalVM等等&#xff09;的任意版本的JDK。通过下面的命令可以轻易安装sdkman: 2.安装 curl -s "https://…

IFM易福门LR3000LR3300液位传感器操作说明

IFM易福门LR3000LR3300液位传感器操作说明

使用ssh-remote连接远程vscode运行yolo项目时的一点坑

使用ssh-remote连接远程vscode运行yolo项目时的一点坑 1.坑1 因为我是直接下载的release包&#xff0c;然后运行 pip install -e .来下载依赖的&#xff0c;那么这个时候需要使用YOLO时都需要在下载的release文件的目录下的py文件才能生效 比方说我下载的yolov8(ultralytic…

SpringBoot 快速上手

1. 环境准备 ⾃检Idea版本: 社区版: 2021.1 -2022.1.4 专业版: ⽆要求 如果个⼈电脑安装的idea不在这个范围, 需要卸载重新安装. Idea 卸载参考: https://blog.csdn.net/qq_19072921/article/details/126408402 (⼀定要删除注册表) 2. Maven 2.1 什么是Maven 官⽅…

Stable Diffusion 模型的安装和使用

一、SD模型简介 Stable Diffusion的绘图风格主要由模型来控制&#xff0c;基础模型主要由二次元图片训练获得&#xff0c;所以在不安装其他模型的情况下&#xff0c;只能生成二次元风格的图像。 模型能够有效地控制生成的画风和内容。 常用的模型网站有&#xff1a; Stable D…

Taro 框架中使用iconfont 阿里巴巴矢量图标 class版

想必大家都知道这个图标库的 图标还是很多的‘ 大家应该都也用过 最进开发 Taro nut-ui 的H5 移动端的时候 我发现一些图标我在组件库中找不到 我看到了nut-ui 中还有另一种使用方法 这个叫做 自定一图标 、 我来用实际操作 代码 来介绍一下 这个怎么使用 我总结文章 …

docker环境安装kafka/Flink/clickhouse镜像

1、安装Kafka服务 1、将一下三个tar文件复制到ubuntu指定目录下 2、进入到/home/cl/app目录&#xff0c;使用docker命令加载tar镜像文件 # cd /home/cl/app # docker load -i kafka.tar # docker load -i kafka-manager.tar # docker load -i kafka-zookeeper.tar3、查看d…

MySQL基础练习题11-换座位

题目&#xff1a;交换每两个连续的学生的座位号。如果学生的数量是奇数&#xff0c;则最后一个学生的id不交换。按 id 升序 返回结果表。 准备数据 分析数据 方法一&#xff1a;利用power函数对id进行交换&#xff0c;得出的答案只有0或1 第一步&#xff1a;用power()函数将…

HDBaseT远距离无压缩传输系统源头厂家

HDBaseT双绞线延长器是一款集成HDBaseT的远距离高清信号无压缩、无延时传输器&#xff0c;HDMI信号从接收端输出&#xff0c; 信号分辨率高达4Kx2K可以通过单根CAT5/CAT6网线将信号长距离传输高清无压缩音视频信号&#xff0c; 采用单根网线最远可传输70/100米&#xff0c; …

Linux 安装 nacos 2.4.0

参看&#xff1a;Nacos 快速开始 2.4.0 版本是Nacos2.X的又一个功能性版本&#xff0c;此版本的更新主要在 Nacos 的安全性、扩展功能和改进用户体验方面的持续努力&#xff0c;为用户提供了更安全、更灵活的服务管理平台。版本主要的功能如下&#xff1a; 增强安全性&#xf…

Duix AI 太上瘾,让我熬夜体验的AI女友

✨点击这里✨&#xff1a;&#x1f680;原文链接&#xff1a;&#xff08;更好排版、视频播放、社群交流、最新AI开源项目、AI工具分享都在这个公众号&#xff01;&#xff09; Duix AI 太上瘾&#xff0c;让我熬夜体验的AI女友 开启 Duix AI 女友的奇妙之旅_ Hi&#xff0c;这…

C++:类和对象2

1.类的默认成员函数 默认成员函数就是用户没有显示实现编译器会自动生成的成员函数称为默认成员函数。一个类&#xff0c;我们在不写的情况下编译器会默认生成6个默认成员函数&#xff0c;分别是构造函数&#xff0c;析构函数&#xff0c;拷贝构造函数&#xff0c;拷贝赋值运算…

前缀和与差分大总结!!!C++

学了忘忘了学o(╥﹏╥)o 题源acwing 讲解前缀和一维&#xff0c;用于序列二维&#xff0c;用于矩阵 讲解差分什么是差分数组&#xff1f;一维差分数组二维差分数组 题目一&#xff1a;前缀和题目二&#xff1a;子矩阵的和题目三&#xff1a;差分题目四&#xff1a;差分矩阵 讲…

案例分享-国外轻松感UI设计赏析

国外UI设计倾向于采用简洁的布局、清晰的排版和直观的交互方式&#xff0c;减少用户的认知负担&#xff0c;从而营造出轻松的使用体验。这种设计风格让用户能够快速找到所需信息&#xff0c;降低操作难度&#xff0c;提升整体满意度。 在注重美观的同时&#xff0c;更加重视用户…

便携移动工作站,端侧 AI 大模型设备折腾笔记:ROG 幻 X 和 4090 扩展坞

为了本地测试和开发更丝滑&#xff0c;最近入手了一套新设备 ROG 幻 X Z13 和 ROG XG Mobile 4090 扩展坞。 基于这套设备&#xff0c;我搭了一套 Windows x WSL2 x CUDA 的开发环境。分享一下折腾记录&#xff0c;或许对有类似需求的你也有帮助。 写在前面 最近因为各种事情…

【MySQL】索引 【下】{聚簇索引VS非聚簇索引/创建主键索引/全文索引的创建/索引创建原则}

文章目录 1.聚簇索引 VS 非聚簇索引经典问题 2.索引操作创建主键索引唯一索引的创建普通索引的创建全文索引的创建查询索引删除索引索引创建原则 1.聚簇索引 VS 非聚簇索引 之前介绍的将所有的数据都放在叶子节点的这种存储引擎对应的就是 InnoDB 默认存储表数据的存储结构。 …

【大模型系列】Video-LaVIT(2024.06)

Paper&#xff1a;https://arxiv.org/abs/2402.03161Github&#xff1a;https://video-lavit.github.io/Title&#xff1a;Video-LaVIT: Unified Video-Language Pre-training with Decoupled Visual-Motional TokenizationAuthor&#xff1a;Yang Jin&#xff0c; 北大&#x…

[Office] Word 特殊字符

0 打开“特殊字符集” 依次选择&#xff1a;Insert -> Symbol -> More Symbol 1 带圈编号 字体Font选择Wingdings

嵌入式Linux:符号链接(软链接)和硬链接

目录 1、符号链接&#xff08;软链接&#xff09; 2、硬链接 3、link()函数 4、symlink()函数 5、readlink()函数 在 Linux 系统中&#xff0c;符号链接&#xff08;软链接&#xff09;和硬链接是两种创建文件链接的方法。理解它们的区别和使用场景对于文件系统的管理非常…

错误:请查看是否设备未加入到证书列表或者确认证书类型是否匹配

这个问题实际上网上都有解法&#xff0c;但是可能没有那么的清楚&#xff0c;大家在各种问&#xff0c;我既然搞定了&#xff0c;就分享给大家吧网上解法&#xff1a; 开发调试需要另外创建开发证书和描述文件&#xff0c;描述文件同时绑定开发设备解读&#xff1a; 实际上这句…