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,用于检查某个子串是否为回文。
相关推荐
Dizzy.51725 分钟前
数据结构(查找)
数据结构·学习·算法
hello_simon1 小时前
【Word转PDF】在线Doc/Docx转换为PDF格式 免费在线转换 功能强大好用
职场和发展·pdf·word·学习方法·word转pdf·石墨文档·word转换
分别努力读书3 小时前
acm培训 part 7
算法·图论
武乐乐~3 小时前
欢乐力扣:赎金信
算法·leetcode·职场和发展
'Debug3 小时前
算法从0到100之【专题一】- 双指针第一练(数组划分、数组分块)
算法
Fansv5874 小时前
深度学习-2.机械学习基础
人工智能·经验分享·python·深度学习·算法·机器学习
测试19985 小时前
接口测试工具:Postman
自动化测试·软件测试·python·测试工具·职场和发展·接口测试·postman
yatingliu20195 小时前
代码随想录算法训练营第六天| 242.有效的字母异位词 、349. 两个数组的交集、202. 快乐数 、1. 两数之和
c++·算法
uhakadotcom6 小时前
Google DeepMind最近发布了SigLIP 2
人工智能·算法·架构
sjsjs116 小时前
【数据结构-并查集】力扣1202. 交换字符串中的元素
数据结构·leetcode·并查集