算法-双指针-秋招算法冲刺

秋招冲刺算法

双指针

数组划分,数组分块

常⻅的双指针有两种形式,⼀种是对撞指针,⼀种是左右指针。

快慢指针

  • 基本思想:使用两个移动速度不同的指针在数组或链表等序列结构上移动。
  • 通常处理结构类型:环形链表或数组。

image-20230613154638391

int slow = 0,fast = 0;
while(fast < length){//相当于right走了一遍,查到分类1的就放到前面。而结束的时候刚好left的下标就是最后一个分类1
    //right指向分类1的情况
    if(arr[right] != 分类2){
        swap(arr[left],arr[right]);
        left++;
    }
    right++;
}

1.移动零

https://leetcode.cn/problems/move-zeroes/

class Solution {
    //分类1 :>0的数
    //分类2 :==0的数
    public void moveZeroes(int[] nums) {
        int left = 0;
        int right =0;
        while(right<nums.length){//这里的分类1 就是>0的数
            if(nums[right]!=0){//当right指向 >0 的数的时候,进行交换
                swap(nums,left,right);
                left++;
            }
            right++;
        }
    }
    public void swap(int[] nums,int left,int right){
        int temp = nums[left];
        nums[left] = nums[right];
        nums[right]  = temp;
    }
}

2.快排核心代码

public void pointerQuicklySort(int[] arr) {
    pointerQuicklySort(arr, 0, arr.length - 1);
}
private void pointerQuicklySort(int[] arr, int left, int right) {
    if (right<=left) return ;
    int root = pointer(arr, left, right);
    pointerQuicklySort(arr, root + 1, right);
    pointerQuicklySort(arr, left, root - 1);
}
private int pointer(int[] arr, int left, int right) {
    int slow = left + 1;//慢指针
    while(fast<=right){
        if(arr[fast]<arr[left]){
            swap(nums,fast,slow);
        	slow++;
        }
        fast++;
    }
    swap(arr, left, slow - 1);//因为到最后slow在带交换的位置上,这位置上的值是大于arr[left]的
    return slow-1;//注意这里也需要slow-1,因为slow位置是基应处位置的右边
}

3.复写零

https://leetcode.cn/problems/duplicate-zeros/

解法:双指针算法,现根据“异地”操作,再优化成“就地”操作。

class Solution {
    public void duplicateZeros(int[] arr) {
//1.定位 fast和slow位置
//都从-1开始,让最后的结果互相对应,fast刚好为slow位置匹配的最后一个数字
        int fast = -1, slow = -1;
        while (fast < arr.length-1) {
            if (arr[slow+1] == 0) {
                slow++;
                fast += 2;
            } else {
                slow++;
                fast++;
            }
        }
//1.5特殊情况判断
//如果这时候slow==0,那么fast位置就会为 arr.length。对这种情况进行处理
        if(fast==arr.length){
            arr[fast-1]=0;
            slow--;
            fast-=2;
        }
//2.开始复写
        while(slow>=0){
            if(arr[slow]==0){
                arr[fast]=0;
                arr[fast-1]=0;
                fast-=2;
                slow--;
            }else{
                arr[fast]=arr[slow];
                fast--;
                slow--;
            }
        }
    }
}

4.快乐数

https://leetcode.cn/problems/happy-number/

按照这个题目走一定会形成环的:int 能形成的最大的数 也不超过 81*10=810 ,一共就有那么多数,但是这种会一直循环无数次,所以一定会产生环,即便这个环只有一个值。

思考方向:判断链表是否有环,使用快慢指针

class Solution {
    public boolean isHappy(int n) {
        int fast = n;int slow = n;
        fast = math(fast);
        while(fast!=slow){
            fast = math(fast);
            fast = math(fast);
            slow = math(slow);
        }
        if(slow==1){
            return true;
        }else{
            return false;
        }
    }
    //写一个函:它每个位置上的数字的平方和
    public int math(int n){
        int ret = 0;
        while(n>0){
            int a = n%10;
            ret+=a*a;
            n/=10;
        }
        return ret;
    }
}

左右针

  • 基本思想:从两端向中间移动。⼀个指针从最左端开始,另⼀个从最右端开始,然后逐渐往中间逼近。

  • 通常处理结构类型:⼀般⽤于顺序结构中,也称左右指针。

1.盛最多水的容器

https://leetcode.cn/problems/container-with-most-water/

image-20230616214122294

import java.util.*;
class Solution {
    public int maxArea(int[] arr) {
        int left = 0,right = arr.length-1;
        int max = 0;
        while(right>left){
            max = Math.max(eara(arr,left,right),max);
            if(arr[left]>arr[right]){
                right--;
            }else{
                left++;
            }
        }
        return max;
    }
    public int eara(int arr[],int left,int right){
        int w = right-left;
        int h = arr[right]<arr[left]?arr[right]:arr[left];
        return w*h;
    }
}

2.剑指 Offer 57. 和为s的两个数字

https://leetcode.cn/problems/he-wei-sde-liang-ge-shu-zi-lcof/

3.三数之和

https://leetcode.cn/problems/3sum/

class Solution {
    //大致思路:固定一个数,剩余的进行 左右指针找
    public List<List<Integer>> threeSum(int[] nums) {
        int left,right;
        List<List<Integer>> ret = new ArrayList<>();
        //1.先进行排序
        Arrays.sort(nums);
        //2.固定一个数
        for(int i=0;i<nums.length;i++){
            //当固定的数 为正数的时候,后面的就没必要判断了
            //因为 无论多少个正数想加都还是正数
            if(nums[i]>0){break;}
 
            left = i+1;
            right = nums.length-1;
            while(right>left){
                if(nums[left]+nums[right]+nums[i] == 0){
                    //System.out.println(nums[left]+" "+nums[right]+" "+nums[i]);
                    List<Integer> list = new ArrayList<>();
                    list.add(nums[i]);
                    list.add(nums[left]);
                    list.add(nums[right]);
                    ret.add(list);
                    left++;right--;
                    //找到之后要进行去重
                    //找到之后:重复的都是复合条件的,已经符合的数直接删掉即可
                    //左右去重:[0,0,0,0]
                    while(right>left && nums[right] == nums[right+1]){
                        right--;
                    }
                    while(right>left && nums[left] == nums[left-1]){
                        left++;
                    }
                }else if(nums[left]+nums[right]+nums[i] > 0){
                    right--;
                }else{
                    left++;
                }
            }
            //根去重:[-1,-1,0,1,2]
            while(i<nums.length-1&&nums[i+1] == nums[i]){
                i++;
            }
        }
        return ret;
    }
}

4.四数之和

https://leetcode.cn/problems/4sum/

和三数想加,思路一样,重点还是 细节把控:重复值的删除

class Solution {
    public List<List<Integer>> fourSum(int[] nums, int target) {
        Arrays.sort(nums);
        List<List<Integer>> ret = new LinkedList<>();
        int left,right;
        for(int i=0;i<nums.length-1;i++){
            for(int j=i+1;j<nums.length-1;j++){
                left = j+1;
                right = nums.length-1;
                while(right>left){
                    //注意int 越界的情况 还强制转换成 long
                    if((long)nums[i]+nums[j]+nums[left]+nums[right] == (long)target){
                        List<Integer> list = new LinkedList<>();
                        list.add(nums[i]);
                        list.add(nums[j]);
                        list.add(nums[left]);
                        list.add(nums[right]);
                        ret.add(list);
                        while(right>left && nums[left+1]==nums[left]){
                            left++;
                        }
                        while(right>left && nums[right-1]==nums[right]){
                            right--;
                        }
                        left++;
                        right--;
                    }else if(nums[i]+nums[j]+nums[left]+nums[right] > target){
                        right--;
                    }else{
                        left++;
                    }
                }
                while(j<nums.length-2 && nums[j+1] == nums[j]){j++;}
            }
            while(i<nums.length-2 && nums[i+1] == nums[i]){i++;}
        }
        return ret;
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Cortext-M3系统:储存器系统(2)

1、存储系统功能概览 Cortext-M3储存器有如下特点&#xff1a; 存储器映射是预定义的&#xff0c;并且还规定好了哪个位置使用哪条总线。 存储器系统支持所谓的“位带”&#xff08;bit-band&#xff09;操作。通过它&#xff0c;实现了对单一比特的原子操作&#xff0c;位带操…

【数据库三】数据库的存储引擎

存储引擎 1.存储引擎1.1 概念介绍1.2 常用存储引擎 2.MyISAM2.1 特点介绍2.2 支持的存储格式2.3 适用的生产场景 3.InnoDB3.1 特点介绍3.2 适用生产场景分析4.企业选择存储引擎依据 5.MyISAM和InnoDB的区别命令操作 1.存储引擎 1.1 概念介绍 MySQL数据库中的组件&#xff0c;负…

腾讯云+PicGo+Typora图床,生成专属图片链接

腾讯云PicGoTypora搭建自己的图床 原创声明&#xff0c;转载请注明文章链接来源、作者信息 TyporaPicGogitHub搭建自己的图床&#xff0c;写作效率大大提升 索奇问答 问&#xff1a;图床是什么&#xff1f; 答&#xff1a;用户可以将图片上传到图床&#xff0c;然后将生成的…

基于U-Net网络实现图像分割

目录 1、作者介绍2、U-Net网络及数据集介绍2.1 U-Net网络2.2 数据集介绍2.2.1 VOC_2012数据集2.2.2 眼球毛细血管数据集2.2.3 医学图像数据集 3、U-Net实现图像分割3.1 U-Net实现图像分割实验&#xff08;简易版本&#xff09;3.1.1 环境配置3.1.2 数据集准备3.1.3 代码实现3.1…

(十)异步-使用异步(3)

一、GUI 程序中的异步操作 1、在 GUI 程序中使用异步操作 在 GUI程序中&#xff0c; 首先理解关于 UI 显示变化的概念。 消息&#xff1a; UI 上的行为&#xff0c;如点击按钮、展示标签、移动窗体等。消息队列&#xff1a; 把要触发的所有消息&#xff0c;都按照相关的顺序…

CSDN 周赛 59 期

CSDN 周赛 59 期 前言判断题单选题题目1题目2填空题编程题1、题目名称:坏掉的打字机2、题目名称:布尔零点计数小结前言 由于最近,csdn 每日一练新增了两个题目,按照惯例,那么新增的题目,会就近出现在最近的 CSDN 周赛中,嗯,经常参加周赛,并关注每日一练社区的小伙伴应…

IO流(C++)

IO流C C语言的输入与输出流是什么CIO流C标准IO流C文件IO流二进制读写文本读写 stringstream的简单介绍 C语言的输入与输出 C语言中我们用到的最频繁的输入输出方式就是scanf ()与printf()。 scanf(): 从标准输入设备(键 盘)读取数据&#xff0c;并将值存放在变量中。printf():…

阿里云国际站代理商:如何优化阿里云服务器的性能和响应速度?有哪些调优策略和建议?

随着互联网的发展&#xff0c;阿里云服务器已经成为很多企业和个人的首选解决方案。然而&#xff0c;面对不断增长的需求和复杂的网络环境&#xff0c;如何优化阿里云服务器的性能和响应速度&#xff0c;提高用户体验&#xff0c;是很多用户关心的问题。本文将从以下几个方面&a…

MsSqlServer配置管理器TCP/IP属性

TCP/IP 属性&#xff08;“IP 地址”选项卡&#xff09; 使用 “TCP/IP 属性&#xff08;‘IP 地址’选项卡&#xff09;” 对话框&#xff0c;可以配置特定 IP 地址的 TCP/IP 协议选项。 只有选中 “IP All” &#xff0c;才能一次配置所有地址的 “TCP 动态端口” 和 “TCP…

Debian openssh-server 的安装

在之前安装系统的时候有一个安装 SSH 服务的&#xff0c;结果没点上&#xff0c;导致系统完成后&#xff0c;ssh无法连接上啊&#xff0c;于是要安装sshd 服务。使用命令&#xff1a;apt-get install openssh-server 结果就出现问题了&#xff1a; 网上搜索说是要更新源&#x…

catkin cmake官方教程解读以及资料补充

这里写目录标题 报错cmakei下载cmake 官方教程教程1step1最低版本 报错报错2 vscode 路径没有配置好setting.json通过该方式打开的似乎是一个全局的文件&#xff0c;可以为本工作文件夹下设置一个本地的吗 报错3配置cmake工具链准确的流程报错4 cpp中main函数返回值问题结果 官…

Verilog基础:标识符的向上向下层次名引用

相关文章 Verilog基础&#xff1a;表达式位宽的确定&#xff08;位宽拓展&#xff09; Verilog基础&#xff1a;表达式符号的确定 Verilog基础&#xff1a;数据类型 Verilog基础&#xff1a;位宽拓展和有符号数运算的联系 Verilog基础&#xff1a;case、casex、ca…

如何在Microsoft Excel中使用TRUNC函数

Excel 中有多种删除小数点和缩短数值的方法。在本文中,我们将解释如何使用 TRUNC 函数,以及它与其他技术的不同之处。 TRUNC函数 什么是 TRUNC 功能如何使用 TRUNC 函数从日期时间戳中删除时间什么是 TRUNC 功能 TRUNC 函数将数字截断为指定的小数位数。使 TRUNC 不同于其他…

概率论与数理统计教程第五章节笔记

参考书籍&#xff1a;概率论与数理统计教程第三版 茆诗松 程依明 濮晓龙 编著 文章声明&#xff1a;如有错误还望批评指正 文章目录 ξ 5.1 \xi5.1 ξ5.1总体与样本 ξ 5.2 \xi5.2 ξ5.2样本数据的整理与显示Python绘制直方图Python绘制茎叶图 ξ 5.3 \xi5.3 ξ5.3统计量及其分…

基於Hadoop HA 在kerberos中配置datax

概要 提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 概要 前言一、基於HADOOP HA 搭建datax二、基於HADOOP HA 配置好的datax去配置kerberos1.在datax的配置文件中進行配置2.在shell腳本中加入認證語句 总结 前言…

layui框架学习(27:弹出层模块_其它用法)

除了前几篇文章介绍的弹出框类型外&#xff0c;layui的layer弹出层模块还支持相册框和tab框&#xff0c;所谓相册框即点击图片或按钮后会出现一个类似相册的页面单独浏览、切换图片&#xff0c;而tab框是指弹出框的显示形式类似于Winform中的TabControl控件&#xff0c;能以选项…

【Spring Security】的RememberMe功能流程与源码详解

文章目录 前言原理 基础版搭建初始化sql依赖引入配置类验证 源码分析 进阶版集成源码分析疑问1疑问2 鉴权 升级版集成初始化sql配置类验证 源码分析鉴权流程 扩展版 前言 之前我已经写过好几篇权限认证相关的文章了&#xff0c;有想复习的同学可以查看【身份权限认证合集】。今…

MIT 6.S081 Lab Four

MIT 6.S081 Lab Four 引言trapsRISC-V assembly (easy)代码解析 Backtrace(moderate)代码解析 Alarm(Hard)test0: invoke handler(调用处理程序)test1/test2(): resume interrupted code(恢复被中断的代码)代码解析issue解答 可选的挑战练习 引言 本文为 MIT 6.S081 2020 操作…

JDBC BasicDAO详解(通俗易懂)

目录 一、前言 二、BasicDAO的引入 1.为什么需要BasicDAO&#xff1f; 2.BasicDAO示意图 : 三、BasicDAO的分析 1.基本说明 : 2.简单设计 : 四、BasicDAO的实现 0.准备工作 : 1.工具类 : 2.JavaBean类 : 3.BasicDAO类 / StusDAO类 : 4.测试类 : 一、前言 第七节内容…

Jenkins+Docker 实现一键自动化部署项目!步骤齐全,少走坑路

大家好&#xff0c;我是互联网架构师&#xff01; 本文章实现最简单全面的Jenkinsdockerspringboot 一键自动部署项目&#xff0c;步骤齐全&#xff0c;少走坑路。 环境&#xff1a;centos7git(gitee) 简述实现步骤&#xff1a;在docker安装jenkins&#xff0c;配置jenkins基…