LeetCode-680. 验证回文串 II

1、题目描述:

给你一个字符串 s最多 可以从中删除一个字符。

请你判断 s 是否能成为回文字符串:如果能,返回 true ;否则,返回 false

示例 1:

复制代码
输入:s = "aba"
输出:true

示例 2:

复制代码
输入:s = "abca"
输出:true
解释:你可以删除字符 'c' 。

示例 3:

复制代码
输入:s = "abc"
输出:false

提示:

  • 1 <= s.length <= 105
  • s 由小写英文字母组成

2、代码:

cpp 复制代码
class Solution {
public:
    // 辅助函数:判断子串 [left, right] 是否为回文
    bool isPalindNum(string s, int left, int right) {
        // 使用双指针法检查子串是否为回文
        while (left < right) {
            if (s[left] != s[right]) {
                // 如果左右字符不相等,说明不是回文,返回 false
                return false;
            }
            left++;  // 左指针向右移动
            right--; // 右指针向左移动
        }
        // 如果循环结束,说明子串是回文,返回 true
        return true;
    }

    // 主函数:判断字符串 s 是否可以通过最多删除一个字符成为回文
    bool validPalindrome(string s) {
        int left = 0, right = s.size() - 1; // 定义左右指针

        // 使用双指针法遍历字符串
        while (left < right) {
            if (s[left] == s[right]) {
                // 如果左右字符相等,继续向内移动指针
                left++;
                right--;
                continue; // 跳过后续逻辑,继续下一次循环
            } else {
                // 如果左右字符不相等,尝试跳过左边或右边的字符
                // 跳过左边字符:检查子串 [left+1, right] 是否为回文
                // 跳过右边字符:检查子串 [left, right-1] 是否为回文
                return isPalindNum(s, left + 1, right) ||
                       isPalindNum(s, left, right - 1);
            }
        }

        // 如果循环结束,说明字符串已经是回文,返回 true
        return true;
    }
};

3、解题思路

  1. 回文的定义

    • 一个字符串是回文,当且仅当从左到右和从右到左读起来是一样的。
  2. 双指针法

    • 使用两个指针 leftright 分别指向字符串的开头和结尾。
    • 如果 s[left] == s[right],则继续向内移动指针(即 left++right--)。
    • 如果 s[left] != s[right],说明需要删除一个字符:
      • 尝试跳过左边的字符(即检查子串 s[left+1] 到 s[right] 是否为回文)。
      • 或者尝试跳过右边的字符(即检查子串 s[left]到 s[right-1] 是否为回文)。
    • 如果上述两种情况中任意一种满足回文条件,则返回 true;否则返回 false
  3. 辅助函数

    • 定义一个辅助函数 isPalindromeRange,用于检查某个子串是否为回文。
相关推荐
丁浩66639 分钟前
Python机器学习---2.算法:逻辑回归
python·算法·机器学习
伏小白白白1 小时前
【论文精度-2】求解车辆路径问题的神经组合优化算法:综合展望(Yubin Xiao,2025)
人工智能·算法·机器学习
无敌最俊朗@2 小时前
数组-力扣hot56-合并区间
数据结构·算法·leetcode
囚生CY2 小时前
【速写】优化的深度与广度(Adam & Moun)
人工智能·python·算法
码农多耕地呗2 小时前
力扣94.二叉树的中序遍历(递归and迭代法)(java)
数据结构·算法·leetcode
微笑尅乐3 小时前
BFS 与 DFS——力扣102.二叉树的层序遍历
leetcode·深度优先·宽度优先
懒羊羊不懒@3 小时前
Java基础语法—最小单位、及注释
java·c语言·开发语言·数据结构·学习·算法
白云千载尽4 小时前
leetcode 912.排序数组
算法·leetcode·职场和发展
哆啦刘小洋4 小时前
Tips:预封装约束的状态定义
算法
代码充电宝4 小时前
LeetCode 算法题【简单】290. 单词规律
java·算法·leetcode·职场和发展·哈希表