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,用于检查某个子串是否为回文。
相关推荐
啥都鼓捣的小yao20 分钟前
Python使用SVC算法解决乳腺癌数据集分类问题——寻找最佳核函数
python·算法·分类
安然无虞36 分钟前
31天Python入门——第14天:异常处理
后端·爬虫·python·职场和发展·pyqt
小鸭呱呱呱1 小时前
【CSS】- 表单控件的 placeholder 如何控制换行显示?
前端·javascript·css·深度学习·面试·职场和发展·html
三分钟管理实战案例1 小时前
应对传统能源企业人才短缺与规划缺失的策略
职场和发展·能源
Java版蜡笔小新2 小时前
算法-贪心算法
算法·贪心算法
LuckyAnJo2 小时前
Leetcode-100 回溯法-电话号码的字母组合
python·算法·leetcode
HR Zhou2 小时前
群体智能优化算法-鹈鹕优化算法(Pelican Optimization Algorithm, POA,含Matlab源代码)
算法·机器学习·matlab·优化·群体智能优化
LuckyLay2 小时前
LeetCode算法题(Go语言实现)_20
算法·leetcode·职场和发展·golang
Phoebe鑫3 小时前
数据结构每日一题day7(顺序表)★★★★★
算法
Suc_zhan5 小时前
实验二 如何将随机森林算法应用于激酶抑制剂分类任务
python·算法·随机森林·机器学习