双指针:回文字符串(680)

Snipaste_20200703_160643.jpg
题目描述:可以删除一个字符,判断是否能构成回文字符串。
所谓的回文字符串,是指具有左右对称特点的字符串,例如 "abcba" 就是一个回文字符串。

Input: "abca"
Output: True
Explanation: You could delete the character 'c'.

          
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
var validPalindrome = function (s) { let indexLeft = 0 let indexRight = s.length - 1 while (indexLeft <= indexRight) { if (s[indexLeft] !== s[indexRight]) { if (isSymmetric(s.slice(indexLeft, indexRight))) { return true } else { if (isSymmetric(s.slice(indexLeft + 1, indexRight + 1))) { return true } else { return false } } } else { indexLeft++ indexRight-- } } return true function isSymmetric(s1) { let Left = 0 let Right = s1.length - 1 while (Left <= Right) { if (s1[Left] === s1[Right]) { Left++ Right-- } else { return false } } return true } };

js第一次写出的解法,思路:先比较两端是否相等,删除一端一个元素后再用函数判断是否是对称的

          
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
#python3 class Solution: def validPalindrome(self, s: str) -> bool: if s==s[::-1]: return True left,right=0,len(s)-1 while left<=right: if s[left]==s[right]: left+=1 right-=1 else: a,b=s[left+1:right+1],s[left:right] print(a,b) return a==a[::-1] or b==b[::-1]

主要思路:判断是否对称就是把字符串倒过来看是否相等,采用s==s[::-1]正反向字符串对称做判定,后采用双指针来做切片删除处理

思路图
(完)
成都3日游
春熙路太古里 - 九眼桥 - 望平街,熊猫基地 - 文殊院 - 宽窄巷子 - 锦里,成都博物馆 - 少城小学 - 人民公园
谈谈债券,可转债,国债
债券到底是什么?可转债和债券的关系?可转债啥时卖?国债利率上升对股市,经济产生的影响?
一本书读懂财报--利润表
利润表解读
何时用 useCallback 和 useMemo
了解即可,做优化时再用
vite创建vue3项目 eslint+prettier+stylelint
eslint+prettier+stylelint配置
FFmpeg Batch AV Converter
推荐一款好用的格式转换工具
等待你的评论