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,用于检查某个子串是否为回文。
相关推荐
IT猿手9 分钟前
基于强化学习 Q-learning 算法求解城市场景下无人机三维路径规划研究,提供完整MATLAB代码
神经网络·算法·matlab·人机交互·无人机·强化学习·无人机三维路径规划
万能程序员-传康Kk3 小时前
旅游推荐数据分析可视化系统算法
算法·数据分析·旅游
PXM的算法星球3 小时前
【并发编程基石】CAS无锁算法详解:原理、实现与应用场景
算法
ll7788113 小时前
C++学习之路,从0到精通的征途:继承
开发语言·数据结构·c++·学习·算法
烨然若神人~4 小时前
算法第十七天|654. 最大二叉树、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树
算法
爱coding的橙子4 小时前
每日算法刷题Day2 5.10:leetcode数组1道题3种解法,用时40min
算法·leetcode
阳洞洞4 小时前
leetcode 18. 四数之和
leetcode·双指针
程序媛小盐5 小时前
贪心算法:最小生成树
算法·贪心算法·图论
Panesle5 小时前
分布式异步强化学习框架训练32B大模型:INTELLECT-2
人工智能·分布式·深度学习·算法·大模型
多多*5 小时前
算法竞赛相关 Java 二分模版
java·开发语言·数据结构·数据库·sql·算法·oracle