力扣(LeetCode)验证回文字符串II 个人题解
给定一个非空字符串 s
,最多删除一个字符。判断是否能成为回文字符串。
示例 1:
输入: "aba" 输出: True
示例 2:
输入: "abca" 输出: True 解释: 你可以删除c字符。
注意:
- 字符串只包含从 a-z 的小写字母。字符串的最大长度是50000。
使用双指针,用指针移动模拟删除一个字符,具体实现如下所示
代码如下:
class Solution { public boolean validPalindrome(String s) { int left = 0; int right = s.length() - 1; while (left < right) { if (s.charAt(left) != s.charAt(right)) { return isPalindrome(s,left+1,right)||isPalindrome(s,left,right-1); } left++; right--; } return true; } boolean isPalindrome(String s,int l,int r) { while(l<r) { if(s.charAt(l) != s.charAt(r)) return false; l++; r--; } return true; } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】博客园2025新款「AI繁忙」系列T恤上架,前往周边小店选购
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步