破解面试难题:面试经典150题 之双指针法详解与代码实现

2024-05-29 14:20

本文主要是介绍破解面试难题:面试经典150题 之双指针法详解与代码实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

面试经典 150 题 - 学习计划 - 力扣(LeetCode)全球极客挚爱的技术成长平台icon-default.png?t=N7T8https://leetcode.cn/studyplan/top-interview-150/

125. 验证回文串

125. 验证回文串

 STL容器

思路:

  1. 遍历输入的字符串,将其中的字母字符转换为小写,并保留数字字符,放入另一个字符串 s1 中。
  2. 将 s1 复制给另一个字符串 s2
  3. 将 s1 反转,得到逆序字符串。
  4. 比较原字符串 s1 和逆序字符串 s2 是否相等,若相等则返回 true,否则返回 false
class Solution {
public:bool isPalindrome(string s) {string s1;for(auto &c : s) {if((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')) { s1 += tolower(c);} else if(c >= '0' && c <= '9'){ s1 += c;}}string s2;s2=s1;reverse(s1.begin(),s1.end());if(s1 == s2)return true;elsereturn false;}
};
双指针

思路:

  1. 遍历输入的字符串,将其中的字母字符转换为小写,并保留数字字符,放入另一个字符串 s1 中。
  2. 初始化两个指针 left 和 right 分别指向 s1 的开头和结尾。
  3. 使用双指针方法,依次比较 left 和 right 指向的字符,如果不相等,则返回 false;如果相等,则继续向中间移动指针。
  4. 如果遍历完成后都没有出现不相等的情况,说明该字符串是回文字符串,返回 true
class Solution {
public:bool isPalindrome(string s) {string s1;for(auto &c : s) {if((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')) { s1 += tolower(c);} else if(c >= '0' && c <= '9'){ s1 += c;}}int left = 0;int right = s1.length()-1;while(left<right){if(s1[left] != s1[right])return false;++left;--right;}return true;}
};

 392. 判断子序列

 392. 判断子序列

思路:

  1. 初始化两个指针 i 和 j 分别指向字符串 s 和 t 的起始位置。
  2. 遍历字符串 t,当字符 t[j] 等于字符 s[i] 时,将两个指针都向后移动一位。
  3. 如果最终 i 移动到了 s 的末尾,说明 s 是 t 的子序列,返回 true;否则,返回 false
class Solution {
public:bool isSubsequence(string s, string t) {int i = 0, j = 0;while(i<s.size()&&j<t.size()){if(s[i]==t[j])i++;j++;}   if(i==s.size())return true;return false;}
};

 167. 两数之和 II - 输入有序数组

167. 两数之和 II - 输入有序数组

思路:

  1. 使用双指针,一个指针 i 指向数组的起始位置,另一个指针 j 指向数组的末尾位置。
  2. 在每次迭代中,计算指针 i 和指针 j 指向的元素之和 numbers[i] + numbers[j]
  3. 如果和大于目标值 target,则将指针 j 向左移动一位,以减小和的值。
  4. 如果和小于目标值 target,则将指针 i 向右移动一位,以增加和的值。
  5. 如果和等于目标值 target,则找到了符合条件的数对,将它们的索引加1并加入结果数组中,然后退出循环。(因为只有一对正确的答案)
  6. 最终返回结果数组。
class Solution {
public:vector<int> twoSum(vector<int>& numbers, int target) {vector<int>res;int i=0;int j=numbers.size()-1;while(i<j){if(numbers[i]+numbers[j]>target)j--;else if(numbers[i]+numbers[j]<target)i++;else{res.push_back(i+1);res.push_back(j+1);break;}}return res;}
};

 11. 盛最多水的容器

11. 盛最多水的容器

思路:

  1. 使用双指针,一个指针 i 指向数组的起始位置,另一个指针 j 指向数组的末尾位置。
  2. 在每次迭代中,计算当前容器的容量,即 (j - i) * min(height[i], height[j])
  3. 每次计算完容量后,更新记录的最大容量 mx,将当前容量与 mx 比较取较大值。
  4. 如果 height[i] < height[j],则移动指针 i 向右一位;否则移动指针 j 向左一位。
  5. 重复步骤 2 到 4,直到指针 i 和 j 相遇为止。
  6. 返回记录的最大容量 mx
class Solution {
public:int maxArea(vector<int>& height) {int i=0;int j=height.size()-1;int mx=0,s=0;while(i<j){s=(j-i)*min(height[i],height[j]);mx=max(mx,s);if (height[i] < height[j]) {i++;} else {j--;}}return mx;}
};

15. 三数之和

15. 三数之和

思路:

  1. 首先对数组进行排序,这样可以方便地使用双指针来遍历数组。
  2. 然后使用三个指针 ileftright 分别指向排序后数组中的每个元素、当前元素的下一个元素和数组末尾元素。
  3. 在每一轮循环中,固定指针 i,并初始化 left = i + 1 和 right = n - 1,其中 n 是数组的长度。
  4. 在 left 和 right 指针确定的范围内,使用双指针技巧来寻找和为 0 的两个数。
  5. 如果找到了满足条件的三元组,则将其加入结果集中,并且需要注意去重。
  6. 继续遍历数组,直到 i 指针到达倒数第三个元素为止。
class Solution {
public:vector<vector<int>> threeSum(vector<int>& nums) {vector<vector<int>> res;int n = nums.size();sort(nums.begin(), nums.end());for (int i = 0; i < n - 2; ++i) {if (i > 0 && nums[i] == nums[i - 1])continue;int left = i + 1;int right = n - 1;int target = -nums[i]; while (left < right) {int sum = nums[left] + nums[right];if (sum == target) {res.push_back({nums[i], nums[left], nums[right]});while (left < right && nums[left] == nums[left + 1])left++;while (left < right && nums[right] == nums[right - 1])right--;left++;right--;}else if (sum < target) {left++;} else {right--;}}}return res;}
};

这篇关于破解面试难题:面试经典150题 之双指针法详解与代码实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1013823

相关文章

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT