一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第9天,点击查看活动详情。
Hi, 大家好。我是新人,程序员库里。
今后会按类分享算法题。
今天给大家分享第9道leetcode上数组中使用双指针相关的算法题。
125.验证回文串
leetcode地址:leetcode-cn.com/problems/va…
难度
简单
描述
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明: 本题中,我们将空字符串定义为有效的回文串。
示例1
输入: "A man, a plan, a canal: Panama"
输出: true
解释: "amanaplanacanalpanama" 是回文串
示例2
输入: "race a car"
输出: false
解释: "raceacar" 不是回文串
提示:
1 <= s.length <= 2 * 105- 字符串
s由 ASCII 字符组成
解法一
- 采用指针对撞的原理
- 首先将字符串中的符号去除,然后将字母转换为小写
- 定义左指针left,初始值是0
- 定义右指针,初始值是字符串长度最后一位
- 开始遍历循环,条件是left 小于 right
- 当left指向的元素等于right指向的元素时,说明目前位置左右两边时相同的元素。left继续向右移动一位,right继续向左移动一位。
- 如果两个不相等,表示不是回文字符串,返回false
- 遍历完后,如果都相等,则是回文字符串,返回true
解法二
优先处理字符串,正则替换所有非数字、字母为空; 双指针,m,n分别从前后出发,对比每一项; 如果相同,则m++,n--,对比下一位;否则直接返回false,执行结束; 如果对比结束均相同,则返回true;
下面采用解法一:
代码
/**
* @param {string} s
* @return {boolean}
*/
var isPalindrome = function(s) {
const arr = s.replace(/[^a-z0-9A-Z]/ig,'').toLowerCase()
console.log(arr)
let left = 0 , right = arr.length-1;
while(left < right){
if(arr[left] === arr[right]){
left++
right--
}else{
return false
}
}
return true
};