LeetCode算法技巧之双指针(左右指针,快慢指针,排序+双指针)

news/2024/4/19 9:46:33/文章来源:https://blog.csdn.net/ji_meng/article/details/126912740

文章目录

  • 前言
  • 左右指针
    • 1.lc125 验证回文串
    • 2.lc5 最长回文子串
    • 3. lc344 反转字符串
  • 快慢指针
    • 1. lc26 删除有序数组中的重复项
    • 2. lc83 删除排序链表中的重复元素
    • 3. lc27 移除元素
    • 4. lc19 删除链表的倒数第N个节点
    • 5. lc142 环形链表 II
    • 6. lc287 寻找重复数
  • 固定间距指针
  • 双指针+排序

前言

(1)简介

首先明确一下,这里的指针并非C或C++中的指针,从名字容易产生误解,这只是一种算法思想,也不是一种数据结构。

这里的指针准确的说其实就是索引,回想在数组遍历的时候,经常会写for循环,用一个指针来记录当前遍历的项(arrays[ i ])。那么双指针实际上就是有两个这样的指针

一般可以分为左右指针,快慢指针,和固定间距指针(滑动窗口中常见,文章链接)

(2)应用场景
数组,字符串,链表等

数组和字符串:前后指针较多,快慢指针也有
链表:快慢指针(因为链表没有索引,不容易得到尾指针)

个人感觉,快慢指针要比前后指针难一点,技巧更多点

左右指针

两个指针相向而行或者相背而行

1.lc125 验证回文串

lc125 链接

描述:

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串

示例:

输入: s = “A man, a plan, a canal: Panama”
输出:true

Solution:
回文串是一个经典问题。验证方法很多,比如双指针,API(reverse),栈

这里讲一下前两种

简单又暴力的API如下(空间复杂度较高)

 public boolean isPalindrome(String s) {String s1 = s.replaceAll("[^A-Za-z0-9]","").toLowerCase();StringBuilder sb = new StringBuilder(s1);return sb.reverse().toString().equals(s1) ;
}

双指针如下

public boolean isPalindrome(String s) {int left=0, right = s.length()-1; // 双指针while(left<right){while(left<right && !Character.isLetterOrDigit(s.charAt(left)))left++;while(left<right && !Character.isLetterOrDigit(s.charAt(right)))right--;if(Character.toLowerCase(s.charAt(left))!=Character.toLowerCase(s.charAt(right)))return false;left++;right--;     }return true;}

当然还可以开辟一个String或StringBuilder类,这样处理更方便些(缺点当然是费空间)

最后,可以看一下 lc9 链接 也是回文串,不同的是给的输入是数字。第一种解法就是直接转化为字符串(熟悉Java API的使用),但是费空间;第二种就是对数字本身处理,这就不属于双指针的内容了。

2.lc5 最长回文子串

lc5 链接

描述:

给你一个字符串 s,找到 s 中最长的回文子串

示例:

输入:s = “babad”
输出:“bab”(“aba” 同样是符合题意)

Solution:
左右指针,相背而行!利用中心拓展法,从中间开始,然后往两边双指针

    int left=0,right=0;int maxLen=0;public String longestPalindrome(String s) {int len = s.length();for(int i=0;i<s.length();i++){longestPallindrome(s,i,i,len); // 以i为中心longestPallindrome(s,i,i+1,len);  // 以i+1为中心}return s.substring(left,right+1);      }public void longestPallindrome(String s,int i,int j,int len){while(i>=0 && j<len && s.charAt(i)==s.charAt(j)){if(j-i+1>maxLen){left = i;right = j;   maxLen = j-i+1; }i--;j++;}}

还可以用动态规划!

3. lc344 反转字符串

LeetCode字符串 文章中有介绍,比较简单,这里就不说了

快慢指针

两个指针同向而行,一快一慢(即两个指针步长不同)

1. lc26 删除有序数组中的重复项

lc26链接

描述:

给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致

示例:

输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]

Solution:

 public int removeDuplicates(int[] nums) {int slow = 0;for(int fast=1;fast<nums.length;fast++){if(nums[fast]!=nums[slow]){slow++;nums[slow] = nums[fast];  }}return slow+1;}

2. lc83 删除排序链表中的重复元素

lc83链接

此题与上一题几乎一样(就是把数组改成链表)
Solution:

public ListNode deleteDuplicates(ListNode head) {if(head==null )return null;ListNode slow=head,fast=head.next;while(fast!=null){if(fast.val !=slow.val){slow.next = fast;slow = slow.next;}fast = fast.next;}slow.next = null;return head;}

3. lc27 移除元素

简单说就是给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素

之前文章有过 见题解

4. lc19 删除链表的倒数第N个节点

描述:

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点

示例:

输入:head = [1,2,3,4,5], n = 2
输出:[1,2,3,5]

Solution:
链表中的文章介绍过,可以说是个固定间距的双指针

public ListNode removeNthFromEnd(ListNode head, int n) {ListNode dummy = new ListNode(-1,head);ListNode slow=dummy,fast = dummy;for(int i=0;i<n+1;i++){fast = fast.next;}while(fast!=null){slow = slow.next;fast = fast.next;}slow.next = slow.next.next;return dummy.next;}

5. lc142 环形链表 II

lc142链接

描述:

给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null

示例:

输入:head = [3,2,0,-4], pos = 1
输出:返回索引为 1 的链表节点

Solution:
先判断链表中是否有环(快慢指针相遇),相遇后在用两个指针分别指向头指针和此时相遇的,再同时出发,相遇点即为环入口。(Floyd 判圈算法)

public ListNode detectCycle(ListNode head) {ListNode fast = head,slow = head;while(fast!=null && fast.next!=null){fast = fast.next.next;slow = slow.next;if(slow==fast){     ListNode index1 = head,index2 = slow;while(index1 != index2){index1 = index1.next;index2 = index2.next;}return index1;}            }return null;          }

6. lc287 寻找重复数

描述:

给定一个包含 n + 1 个整数的数组 nums ,其数字都在 [1, n] 范围内(包括 1 和 n),可知至少存在一个重复的整数。 假设 nums 只有 一个重复的整数 ,返回 这个重复的数 。

你设计的解决方案必须 不修改 数组 nums 且只用常量级 O(1) 的额外空间。

示例:

输入:nums = [1,3,4,2,2] 输出:2

Solution:
看到重复第一反应HashSet,但是题目要求O(1)——利用上题的环形链表

public int findDuplicate(int[] nums) {int slow=0,fast=0;while(true){          slow =nums[slow] ;fast = nums[nums[fast]];if(nums[slow]==nums[fast]){int index=0;while(nums[index]!=nums[slow]){index = nums[index];slow = nums[slow];}return nums[index];}}return 0;}

固定间距指针

见 滑动窗口这篇文章,滑动窗口用到其实就是固定间距指针和快慢指针

双指针+排序

(待定)

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

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

相关文章

MES助力灯具照明行业从制造到”智造”

现如今&#xff0c;LED照明行业产品更新换代太快&#xff0c;一个产品一两年不更新一下外观、材料&#xff0c;就会被对手超越。这直接导致LED产品标准化程度不够高&#xff0c;LED下游制造类厂家智能化生产程度普遍偏低。 加之大多属于劳动密集型产业&#xff0c;传统的依靠买…

less、sass、webpack(前端工程化)

目录 一、Less 1.配置less环境 1.先要安装node&#xff1a;在cmd中&#xff1a;node -v检查是否安装node 2.安装less :cnpm install -g less 3.检查less是否安装成功&#xff1a;lessc -v 4.安装成功后&#xff0c;在工作区创建xx.less文件 5.在控制台编译less,命令&…

Ubuntu16.04使用apache创建个人用户主页并添加口令认证

文章目录一.安装apache二、apache文件和目录简述2.1 网站数据目录2.2 Apache配置文件三、创建个人用户主页3.1 开启个人用户主页功能3.2 建立目录和首页面3.3 开启模块3.4 测试四、添加口令认证4.1 生成密码数据库4.2 修改配置文件一.安装apache 创建虚拟机&#xff0c;保持默…

Python socket之TCP通信、下载文件

TCP简介TCP介绍TCP协议&#xff0c;传输控制协议&#xff08;英语&#xff1a;Transmission Control Protocol&#xff0c;缩写为 TCP&#xff09;是一种面向连接的、可靠的、基于字节流的传输层通信协议&#xff0c;由IETF的RFC 793定义。TCP通信需要经过创建连接、数据传送、…

深入浅出深度学习Pytroch

本文将以通俗易懂的方式&#xff0c;深入浅出地为您揭开深度学习模型构建与训练的面纱&#xff1a; 深度学习数据data模型model损失函数loss优化optimizer可视化visualizer深度学习 数据data 模型model 损失函数loss 优化optimizer 可视化visualizer深度学习数据data模型m…

如何写新闻稿?写好新闻稿的技巧与步骤

新闻稿是传递新闻事件和信息的重要手段&#xff0c;是传媒工作中不可或缺的一部分。写好一篇新闻稿可以让受众了解更多信息&#xff0c;进一步提高他们的关注度。以下是一些写好新闻稿的技巧和步骤&#xff0c;帮助你有效地传达新闻。1、确定新闻的核心信息在开始写新闻稿之前&…

短链或H5唤醒(跳转)APP应用

唤醒APP(两种方法) 一.短链唤醒(跳转)app ⭐ 短链跳转到APP&#xff0c;当如果用户手机不存在APP(某个应用)将会进入到官网页面。 app links实现 在android studio菜单栏Tools->App Links Ass点击,效果图如下 2.配置如下 点击ok,生成如下效果图 3.完成第二步后,会自动…

FreeRTOS入门(01):基础说明与使用演示

文章目录目的基础说明系统移植基础使用演示数据类型和命名风格总结碎碎念目的 FreeRTOS是一个现在非常流行的实时操作系统&#xff08;Real Time Operating System&#xff09;。本文将介绍FreeRTOS入门使用相关内容&#xff0c;这篇是第一篇&#xff0c;主要介绍基础背景方面…

【论文阅读】Anti-Adversarially Manipulated Attributions for WSSS

一篇CVPR2021上的论文&#xff0c;用于弱监督分割及半监督分割 论文标题&#xff1a; Anti-Adversarially Manipulated Attributions for Weakly and Semi-Supervised Semantic Segmentation&#xff08;AdvCAM&#xff09; 作者信息&#xff1a; 代码地址&#xff1a; htt…

2023年华为HCIE-Dacom认证题库(H12-891)

1、如图所示是某位网络工程师在排查OSPF故障时的输出信息。据此判断&#xff0c;以下哪种原因可能导致邻接关系无法正常建立。 Hello报文发送时间不一致认证密码不一致接口的IP地址掩码不一致区域类型不一致 正确答案&#xff1a;C 2、如图所示&#xff0c;路由器的所有接口开启…

ATTCK实战系列——红队实战(二)

网络配置 网卡&#xff1a; WEB&#xff1a; PC&#xff1a; DC&#xff1a; IPWEB10.10.10.80&#xff08;内&#xff09;/192.168.111.80&#xff08;外&#xff09;PC10.10.10.201&#xff08;内&#xff09;/192.168.111.201&#xff08;外&#xff09;DC10.10.10.10物理机…

C++线程/阻塞/同步异步----2

本章节内容为记录改写RTK代码时&#xff0c;学习的知识 同步和异步区别 1.定义不同&#xff1a;同步需要将通信双方的时钟统一到一个频率上&#xff0c;异步通信发送的字符间隔时间可以是任意的; 2.准确性不同&#xff1a;同步通信需要比较高精度的精确度&#xff0c;异步则不…

5.12 BGP选路原则综合实验

配置BGP的选路原则 1. 实验目的 熟悉BGP的选路的应用场景掌握BGP的选路的配置方法2. 实验拓扑 实验拓扑如图5-11所示: 图5-11:配置BGP的选路原则 3. 实验步骤 (1)配置IP地址 R1的配置

你知道 GO 中的 协程可以无止境的开吗?

GO语言天生高并发的语言&#xff0c;那么是不是使用 go 开辟协程越多越好的&#xff0c;那么在 go 里面&#xff0c;协程是不是可以开无限多个呢&#xff1f; 那么我们就一起来看看尝试写写 demo 吧 尝试开辟尽可能多的 协程 写一个 demo &#xff0c;循环开 1 << 31 …

Mac 安装 homebrew

文章目录1. 简介2. 安装2.1 官方安装2.2 安装 ARM 版 Homebrew2.3 安装 X86 版 Homebrew2.4 多版本共存3. 设置镜像3.1 初次安装brew后配置中科大 zsh3.2 换源配置中科大 zsh3.3 换源清华大学 zsh4. 问题1. 简介 omebrew是一款包管理工具&#xff0c;目前支持macOS和linux系统…

「TCG 规范解读」第10章 TPM工作组 保护你的数字环境

可信计算组织&#xff08;Ttrusted Computing Group,TCG&#xff09;是一个非盈利的工业标准组织&#xff0c;它的宗旨是加强在相异计算机平台上的计算环境的安全性。TCG于2003年春成立&#xff0c;并采纳了由可信计算平台联盟&#xff08;the Trusted Computing Platform Alli…

【春秋云境】CVE-2022-28512

靶标介绍&#xff1a; ​ Fantastic Blog (CMS)是一个绝对出色的博客/文章网络内容管理系统。它使您可以轻松地管理您的网站或博客&#xff0c;它为您提供了广泛的功能来定制您的博客以满足您的需求。它具有强大的功能&#xff0c;您无需接触任何代码即可启动并运行您的博客。…

IDEA工具系列之连接Linux

我们在开发的时候&#xff0c;用IDEA开发程序&#xff0c;用XSHELL来管理服务器&#xff0c;这两个工具切换比较麻烦。有没有用IDEA来连接Linux。当然有&#xff0c;下面有实践步骤&#xff1a; 首先&#xff1a;连接Linux 打开IDEA->Tools->Start SSH Session 其中1&…

REDIS09_LBS出现背景、GEO算法介绍、算法步骤、剖析、邻近网格位置推算

文章目录①. LBS出现的背景②. 重新认识经纬度③. 感性认识GeoHash④. Geohash算法介绍⑤. Geohash算法步骤⑥. 更深入剖析GeoHash⑦. 邻近网格位置推算①. LBS出现的背景 ①. 移动互联网时代LBS应用越来越多,所在位置附近三公里的药店、交友软件中附近的小姐姐、外卖软件中附近…

stm32f407探索者开发板(二十)——独立看门狗实验

文章目录一、独立看门狗概述1.1 独立看门狗二、常用寄存器和库函数配置2.1 独立看门狗框图2.2 键值寄存器IWDG_KR2.3 预分频寄存器IWDG_PR2.4 重装载寄存器IWDG_RLR2.5 状态寄存器IWDG_SR2.6 IWDG独立看门狗操作库函数三、手写独立看门狗实验3.1 操作步骤3.2 iwdg.c3.3 iwdg.h3…