【双指针】算法例题

目录

 二、双指针

25. 验证回文数 ①

26. 判断子序列 ①

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

28. 盛最多水的容器 ②

29. 三数之和 ②


 二、双指针

25. 验证回文数 ①

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

字母和数字都属于字母数字字符。

给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false 

示例 1:

输入: s = "A man, a plan, a canal: Panama"
输出:true
解释:"amanaplanacanalpanama" 是回文串。

示例 2:

输入:s = "race a car"
输出:false
解释:"raceacar" 不是回文串。

示例 3:

输入:s = " "
输出:true
解释:在移除非字母数字字符之后,s 是一个空字符串 "" 。
由于空字符串正着反着读都一样,所以是回文串。

提示:

  • 1 <= s.length <= 2 * 105
  • s 仅由可打印的 ASCII 字符组成

方法1:

    public static boolean isPalindrome(String s) {StringBuilder stringBuilder = new StringBuilder();for (int i = 0; i < s.length(); i++) {char c = s.charAt(i);if (Character.isUpperCase(c)){c = Character.toLowerCase(c);}if (Character.isLowerCase(c) || Character.isDigit(c)){stringBuilder.append(c);}}
//        比较的时候要把stringBuilder放左边
//        因为stringBuilder.reverse()会改变stringBuilder的值if (stringBuilder.toString().equals("") || stringBuilder.toString().equals(stringBuilder.reverse().toString())){return true;}else {return false;}}

方法2:

    public boolean isPalindrome(String s) {int first = 0;int last = s.length() - 1;char[] chars = s.toCharArray();while (first < last) {if(chars[first] < 48 || (chars[first] > 57 && chars[first] < 65) || (chars[first] > 90 && chars[first] < 97) || chars[first] > 122) {first++;continue;}if(chars[last] < 48 || (chars[last] > 57 && chars[last] < 65) || (chars[last] > 90 && chars[last] < 97) || chars[last] > 122) {last--;continue;}if(chars[first] < 97) chars[first] += 32;if(chars[last] < 97) chars[last] += 32;if(chars[first] != chars[last]) return false;first++;last--;}return true;}

26. 判断子序列 ①

 给定字符串 s 和 t ,判断 s 是否为 t 的子序列。

字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace""abcde"的一个子序列,而"aec"不是)。

进阶:

如果有大量输入的 S,称作 S1, S2, ... , Sk 其中 k >= 10亿,你需要依次检查它们是否为 T 的子序列。在这种情况下,你会怎样改变代码?

致谢:

特别感谢 @pbrother 添加此问题并且创建所有测试用例。

示例 1:

输入:s = "abc", t = "ahbgdc"
输出:true

示例 2:

输入:s = "axc", t = "ahbgdc"
输出:false

提示:

  • 0 <= s.length <= 100
  • 0 <= t.length <= 10^4
  • 两个字符串都只由小写字符组成。

方法1(2ms)

    public boolean isSubsequence(String s, String t) {int small = 0;for (int i = 0; i < t.length(); i++) {if (small < s.length() && t.charAt(i) == s.charAt(small)){small++;}}if (small == s.length()){return true;}else {return false;}}
    public boolean isSubsequence(String s, String t) {int i = 0, j = 0;while (i < s.length() && j < t.length()) {if (s.charAt(i) == t.charAt(j)){i++;}j++;}return i == s.length();}

方法2:(0ms)

    public boolean isSubsequence(String s, String t) {//运用数组和String APIint index=-1;for(char ch:s.toCharArray()){index=t.indexOf(ch,index+1);if(index==-1){return false;}}return true;}

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

 给你一个下标从 1 开始的整数数组 numbers ,该数组已按 非递减顺序排列  ,请你从数组中找出满足相加之和等于目标数 target 的两个数。如果设这两个数分别是 numbers[index1] 和 numbers[index2] ,则 1 <= index1 < index2 <= numbers.length 。

以长度为 2 的整数数组 [index1, index2] 的形式返回这两个整数的下标 index1  index2

你可以假设每个输入 只对应唯一的答案 ,而且你 不可以 重复使用相同的元素。

你所设计的解决方案必须只使用常量级的额外空间。

示例 1:

输入:numbers = [2,7,11,15], target = 9
输出:[1,2]
解释:2 与 7 之和等于目标数 9 。因此 index1 = 1, index2 = 2 。返回 [1, 2] 。

示例 2:

输入:numbers = [2,3,4], target = 6
输出:[1,3]
解释:2 与 4 之和等于目标数 6 。因此 index1 = 1, index2 = 3 。返回 [1, 3] 。

示例 3:

输入:numbers = [-1,0], target = -1
输出:[1,2]
解释:-1 与 0 之和等于目标数 -1 。因此 index1 = 1, index2 = 2 。返回 [1, 2] 。

提示:

  • 2 <= numbers.length <= 3 * 104
  • -1000 <= numbers[i] <= 1000
  • numbers 按 非递减顺序 排列
  • -1000 <= target <= 1000
  • 仅存在一个有效答案

方法1:(447ms)

    public int[] twoSum(int[] numbers, int target) {int[] result = new int[2];for (int i = 0; i < numbers.length; i++) {for (int j = numbers.length - 1; j > i; j--) {if (numbers[j] == target - numbers[i]){result[0] = i + 1;result[1] = j + 1;return result;}}}return result;}

(1ms)

    public int[] twoSum(int[] numbers, int target) {int[] result = new int[2];int left = 0;int right = numbers.length - 1;while (true){if (numbers[left] + numbers[right] > target){right--;}else if (numbers[left] + numbers[right] < target){left++;}else {result[0] = left + 1;result[1] = right + 1;return result;}}}

28. 盛最多水的容器 ②

 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。

找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。

返回容器可以储存的最大水量。

说明:你不能倾斜容器。

示例 1:

输入:[1,8,6,2,5,4,8,3,7]
输出:49 
解释:图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49。

示例 2:

输入:height = [1,1]
输出:1

提示:

  • n == height.length
  • 2 <= n <= 105
  • 0 <= height[i] <= 104

方法1:(3ms)

    public static int maxArea(int[] height) {int left = 0;int right = height.length - 1;int area = 0;while (left < right){int min = Math.min(height[left], height[right]);if (min * (right - left) > area){area = min * (right - left);}if (min == height[left]){left++;}else {right--;}}return area;}

方法2:(1ms)

    public int maxArea(int[] height) {int l = 0;int r = height.length-1;int max = 0;int minH;while(l<r){minH = Math.min(height[l],height[r]);max = Math.max(max,minH*(r-l));while(l<r&&height[l]<=minH) ++l;while(l<r&&height[r]<=minH) --r;}return max;}

29. 三数之和 ②

 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

你返回所有和为 0 且不重复的三元组。

注意:答案中不可以包含重复的三元组。

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
解释:
nums[0] + nums[1] + nums[2] = (-1) + 0 + 1 = 0 。
nums[1] + nums[2] + nums[4] = 0 + 1 + (-1) = 0 。
nums[0] + nums[3] + nums[4] = (-1) + 2 + (-1) = 0 。
不同的三元组是 [-1,0,1] 和 [-1,-1,2] 。
注意,输出的顺序和三元组的顺序并不重要。

示例 2:

输入:nums = [0,1,1]
输出:[]
解释:唯一可能的三元组和不为 0 。

示例 3:

输入:nums = [0,0,0]
输出:[[0,0,0]]
解释:唯一可能的三元组和为 0 。

提示:

  • 3 <= nums.length <= 3000
  • -105 <= nums[i] <= 105

方法1:(通过311/312)

    public static List<List<Integer>> threeSum(int[] nums) {ArrayList<List<Integer>> result = new ArrayList<>();Arrays.sort(nums);for (int i = 0; i < nums.length; i++) {int left = i;int right = nums.length - 1;int mid = left + 1;while (mid < right){if (nums[mid] + nums[right] + nums[left] < 0){mid++;}else if (nums[mid] + nums[right] + nums[left] > 0){right--;}else {ArrayList<Integer> list = new ArrayList<>();list.add(nums[left]);list.add(nums[mid]);list.add(nums[right]);mid++;right--;if (!result.contains(list)){result.add(list);}}}}return result;}

对以上代码的修改,使得通过所有用例:(38ms)

    public static List<List<Integer>> threeSum(int[] nums) {ArrayList<List<Integer>> result = new ArrayList<>();Arrays.sort(nums);for (int i = 0; i < nums.length; i++) {int left = i;if (i > 0 && nums[i] == nums[i - 1]){continue;}int right = nums.length - 1;int mid = left + 1;while (mid < right){if (nums[mid] + nums[right] + nums[left] < 0){mid++;}else if (nums[mid] + nums[right] + nums[left] > 0){right--;}else {result.add(Arrays.asList(nums[left], nums[mid], nums[right]));while (mid < right && nums[mid +1] == nums[mid]){mid++;}while (mid < right && nums[right] == nums[right - 1]){right--;}mid++;right--;}}}return result;}

方法2:

    public List<List<Integer>> threeSum(int[] nums) {//定义一个结果集List<List<Integer>> res = new ArrayList<>();//数组的长度int len = nums.length;//当前数组的长度为空,或者长度小于3时,直接退出if(nums == null || len <3){return res;}//将数组进行排序Arrays.sort(nums);//遍历数组中的每一个元素for(int i = 0; i<len;i++){//如果遍历的起始元素大于0,就直接退出//原因,此时数组为有序的数组,最小的数都大于0了,三数之和肯定大于0if(nums[i]>0){break;}//去重,当起始的值等于前一个元素,那么得到的结果将会和前一次相同if(i > 0 && nums[i] == nums[i-1]) continue;int l = i +1;int r = len-1;//当 l 不等于 r时就继续遍历while(l<r){//将三数进行相加int sum = nums[i] + nums[l] + nums[r];//如果等于0,将结果对应的索引位置的值加入结果集中if(sum==0){// 将三数的结果集加入到结果集中res.add(Arrays.asList(nums[i], nums[l], nums[r]));//在将左指针和右指针移动的时候,先对左右指针的值,进行判断//如果重复,直接跳过。//去重,因为 i 不变,当此时 l取的数的值与前一个数相同,所以不用在计算,直接跳while(l < r && nums[l] == nums[l+1]) {l++;}//去重,因为 i不变,当此时 r 取的数的值与前一个相同,所以不用在计算while(l< r && nums[r] == nums[r-1]){r--;} //将 左指针右移,将右指针左移。l++;r--;//如果结果小于0,将左指针右移}else if(sum < 0){l++;//如果结果大于0,将右指针左移}else if(sum > 0){r--;}}}return res;}

方法3:(9ms)

    public List<List<Integer>> threeSum(int[] nums) {List<List<Integer>> res = new ArrayList<List<Integer>>();if (nums == null || nums.length < 3) return res;Arrays.sort(nums);for (int i = 0; i < nums.length - 2; i++) {if (i != 0 && nums[i] == nums[i - 1]) continue;int low = i + 1;int high = nums.length - 1;while (low < high) {int sum = nums[low] + nums[high] + nums[i];if (sum == 0) {List<Integer> item = new ArrayList<Integer>();item.add(nums[i]);item.add(nums[low]);item.add(nums[high]);res.add(item);low++;high--;while (low < high && nums[low] == nums[low - 1]) low++;while (low < high && nums[high] == nums[high + 1]) high--;} else if (sum > 0) {high--;} else {low++;}}}return res;}

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

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

相关文章

【进阶五】Python实现SDVRP(需求拆分)常见求解算法——差分进化算法(DE)

基于python语言&#xff0c;采用经典差分进化算法&#xff08;DE&#xff09;对 需求拆分车辆路径规划问题&#xff08;SDVRP&#xff09; 进行求解。 目录 往期优质资源1. 适用场景2. 代码调整3. 求解结果4. 代码片段参考 往期优质资源 经过一年多的创作&#xff0c;目前已经成…

Docker简介与安装

简介 用来快速构建、运行、管理应用的工具简单说&#xff0c;帮助我们部署项目以及项目所依赖的各种组件典型的运维工具 安装 1.卸载旧版 首先如果系统中已经存在旧的Docker&#xff0c;则先卸载&#xff1a; yum remove docker \docker-client \docker-client-latest \dock…

解决虚拟机Linux ens33 没有 IP 地址

解决方法&#xff1a; 先进入 root 模式 sudo su 查看目录 ls /etc/sysconfig 找到上述文件夹 ls /etc/sysconfig/network-scripts/ 用 vim 打开 ifcfg-ens33 这个文件&#xff08;不都是这个名字&#xff0c;按这个方法找到这个文件就行&#xff09; vim /etc/sysconfig/netw…

农业四情监测设备—全面、准确地收集农田环境数据

型号推荐&#xff1a;云境天合TH-Q3】农业四情监测设备是一种高科技的农田监测工具&#xff0c;旨在实时监测和管理农田中的土壤墒情、作物生长、病虫害以及气象条件。这些设备综合运用了传感器、摄像头、气象站等技术手段&#xff0c;能够全面、准确地收集农田环境数据&#x…

H264字节流编码格式

1.H264码流格式——字节流格式 字节流格式是大多数编码器&#xff0c;默认的输出格式。它的基本数据单位为NAL单元&#xff0c;也即NALU。为了从字节流中提取出NALU&#xff0c;协议规定&#xff0c;在每个NALU的前面加上起始码&#xff1a;0x000001或0x00000001&#xff08;0…

Nodejs 第五十八章(大文件上传)

在现代网站中&#xff0c;越来越多的个性化图片&#xff0c;视频&#xff0c;去展示&#xff0c;因此我们的网站一般都会支持文件上传。 文件上传的方案 大文件上传&#xff1a;将大文件切分成较小的片段&#xff08;通常称为分片或块&#xff09;&#xff0c;然后逐个上传这…

【3DsMax】UVW展开——以制作牙膏盒为例

效果 步骤 1. 从网上下载牙膏盒贴图&#xff0c;我下载的贴图地址为&#xff08;牙膏盒贴图链接&#xff09; 2. 打开3DsMax&#xff0c;创建一个长方体&#xff0c;设置长宽高分别为180、45、40毫米 打开材质编辑器&#xff0c;点击漫反射后的按钮 双击“位图” 将材质赋予长…

113 链接集10--ctrl+左键单击多选

1.ctrl+左键单击多选,单击单选 精简代码 <div class="model-list"><div@mousedown.prevent="handleClick(item, $event)"class="model-list-item"v-for="item in modelList":key="item.id":class="{ model-a…

QT6实现创建与操作sqlite数据库及读取实例(一)

一.Qt为SQL数据库提供支持的基本模块&#xff08;Qt SQL&#xff09; Qt SQL的API分为不同层&#xff1a; 驱动层 SQL API层 用户接口层 1.驱动层 对于Qt 是基于C来实现的框架&#xff0c;该层主要包括QSqlDriver&#xff0c;QSqlDriverCreator,QSqlDriverCreatorBase,QSqlPlug…

C++初阶 | [九] list 及 其模拟实现

摘要&#xff1a;介绍 list 容器&#xff0c;list 模拟实现&#xff0c;list与vector的对比 list&#xff08;带头双向循环列表&#xff09; 导入&#xff1a;list 的成员函数基本上与 vector 类似&#xff0c;具体内容可以查看相关文档(cplusplus.com/reference/list/list/)&…

UE4_官方动画内容示例1.1_使用动画资产

对一个SkeletalMeshActor进行设置&#xff0c;设置好之后&#xff0c;可以通过该Actor的细节&#xff08;Details&#xff09;面板播放指定的动画序列&#xff08;AnimationSequence&#xff09;资产&#xff08;例如让Actor翻跟斗并做开合跳&#xff09;。 骨架网格体定义&am…

后端系统开发之——接口参数校验

今天难得双更&#xff0c;大家点个关注捧个场 原文地址&#xff1a;后端系统开发之——接口参数校验 - Pleasure的博客 下面是正文内容&#xff1a; 前言 在上一篇文章中提到了接口的开发&#xff0c;虽然是完成了&#xff0c;但还是缺少一些细节——传入参数的校验。 即用户…

2024计算机二级Python6

在Python语言中局部变量可以是任意标识符&#xff0c;因为局部变量在函数结束时相当于被销毁&#xff0c;即使与全局变量同名也可以正常运行 在函数内部引用数字类型全局变量时&#xff0c;必须使用global保留字声明 函数内部引用组合类型全局变量时&#xff0c;可以不通过gl…

HTML实现卷轴动画完整源码附注释

动画效果截图 页面的html结构代码 <!DOCTYPE html> <html> <head lang=

Python之Web开发中级教程----ubuntu中下载安装Postman

Python之Web开发中级教程----ubuntu中下载安装Postman PostMan 是一款功能强大的网页调试与发送网页 HTTP 请求的 Chrome 插件&#xff0c;可以直接去对我们写出来的路由和视图函数进行调试&#xff0c;作为后端程序员是必须要知道的一个工具。 查看ubuntu系统中是否已经安装了…

微信小程序订阅消息(一次性订阅消息)

1、准备工作 登录微信公众平台–>订阅消息–>在公共模板库中选中一个模版–>将模版id复制&#xff0c;前后端都需要。 点击详情–>查看详细内容模版 复制给后端 2、相关api的使用 前端使用&#xff1a;wx.requestSubscribeMessage wx.openSetting wx.getSetti…

51单片机-蜂鸣器

1.蜂鸣器的介绍 无源蜂鸣器不能一直通电&#xff0c;无源蜂鸣器内部的线圈较小&#xff0c;易烧坏 蜂鸣器的驱动 达林顿晶体管&#xff08;npn型&#xff09; 应用&#xff1a; 按下独立按键同时蜂鸣器响起提示音&#xff0c;数码管显示对应的独立按键键码 #include <REG…

微信小程序 ---- 慕尚花坊 结算支付

结算支付 01. 配置分包并跳转到结算页面 思路分析&#xff1a; 随着项目功能的增加&#xff0c;项目体积也随着增大&#xff0c;从而影响小程序的加载速度&#xff0c;影响用户的体验。 因此我们需要将 结算支付 功能配置成一个分包&#xff0c; 当用户在访问设置页面时&a…

交叉注意力融合时域、频域特征的FFT + CNN -BiLSTM-CrossAttention电能质量扰动识别模型

往期精彩内容&#xff1a; 电能质量扰动信号数据介绍与分类-Python实现-CSDN博客 Python电能质量扰动信号分类(一)基于LSTM模型的一维信号分类-CSDN博客 Python电能质量扰动信号分类(二)基于CNN模型的一维信号分类-CSDN博客 Python电能质量扰动信号分类(三)基于Transformer…

消息队列面试题

目录 1. 为什么使用消息队列 2. 消息队列的缺点 3. 消息队列如何选型&#xff1f; 4. 如何保证消息队列是高可用的 5. 如何保证消息不被重复消费&#xff08;见第二条&#xff09; 6. 如何保证消息的可靠性传输&#xff1f; 7. 如何保证消息的顺序性&#xff08;即消息幂…