《剑指 Offer》专项突破版 - 面试题 18、19 和 20 - 详解回文字符串(C++ 实现)

目录

前言

面试题 18 : 有效的回文

面试题 19 : 最多删除一个字符得到回文

面试题 20 : 回文子字符串的个数



前言

回文是一类特殊的字符串。不管是从头到尾读取一个回文,还是颠倒过来从尾到头读取一个回文,得到的内容是一样的

英语中有很多回文单词,如 "noon" 和 "madam" 等。如果不考虑字符串中的空格和标点符合,并且忽略大小写的不同,那么还有更多有意思的回文,如 "Sir, I demand, I am a maid named Iris." 和 "Bob: Did Anna peep? Anna: Did Bob" 等。

中文博大精深,自然也有很多有趣的回文,如有回文对联 "上海自来水来自海上" 和 "黄山落叶松叶落山黄" 等。如果不考虑标点符号,中文还有 "我为人人,人人为我" 等经典回文。


面试题 18 : 有效的回文

题目

给定一个字符串,请判断它是不是回文。假设只需要考虑字母和数字字符,并忽略大小写。例如,"Was it a cat I saw?" 是一个回文字符串,而 "race a car" 不是回文字符串。

分析

判断一个字符串是不是回文,常用的方法就是使用双指针。可以定义两个指针,一个指针从第 1 个字符开始从前向后移动,另一个指针从最后一个字符开始从后向前移动。如果两个指针指向的字符相同,则同时移动这两个指针来判断它们指向的下一个字符是否相同。这样一直移动下去,直到两个指针相遇

由于题目要求只考虑字母和数字字符,如果某个指针指向的字符既不是字母也不是数字,则移动指针跳过该字符。同时,题目要求忽略大小写,因此需要把所有的字母都转换成小写形式(或大写形式)再做比较。

代码实现

class Solution {
public:bool isPalindrome(string s) {int left = 0, right = s.size() - 1;while (left < right){while (left < right && isalnum(s[left]) == 0)++left;while (left < right && isalnum(s[right]) == 0)--right;if (tolower(s[left]) != tolower(s[right]))return false;++left;--right;}return true;}
};


面试题 19 : 最多删除一个字符得到回文

题目

给定一个非空字符串 s,请判断如果最多从字符串中删除一个字符能不能得到一个回文字符串。

示例 1

输入: s = "abca"
输出: true
解释: 可以删除 "c" 字符 或者 "b" 字符

示例 2

输入: s = "abc"
输出: false

注意

字符串 s 只包含小写英文字母。

分析

和题目 3.1 类似,本题还是从字符串的两端开始向里逐步比较两个字符是不是相同。如果相同,则继续向里移动指针比较里面的两个字符。如果不相同,按照题目的要求,在删除一个字符之后再比较其他的字符就能够形成一个回文。由于事先不知道应该删除两个字符中的哪一个,因此两个字符都可以进行尝试

代码实现

class Solution {
public:bool isPalindrome(string s, int left, int right) {while (left < right){if (s[left] != s[right])return false;++left;--right;}return true;}
​bool validPalindrome(string s) {int left = 0, right = s.size() - 1;while (left < right){if (s[left] != s[right])return isPalindrome(s, left + 1, right) || isPalindrome(s, left, right - 1);++left;--right;}return true;}
};

 


面试题 20 : 回文子字符串的个数

题目

给定一个字符串,请问该字符串中有多少个回文连续子字符串?例如,字符串 "abc" 有 3 个回文子字符串,分别为 "a"、"b" 和 "c";而字符串 "aaa" 有 6 个回文子字符串,分别为 "a"、"a"、"a"、"aa"、"aa" 和 "aaa"。

注意

字符串中只含小写英文字母。

分析

前面都是从字符串的两端开始向里移动指针来判断字符串是否是一个回文,其实也可以换一个方向从字符串的中心开始向两端延伸

如果存在一个长度为 m 的回文子字符串,则分别再向该回文的两端延伸一个字符,并判断回文前后的字符是否相同。如果相同,就找到一个长度为 m + 2 的回文子字符串。例如,在字符串 "abcba" 中,从中间的 "c" 出发向两端延伸一个字符,由于 "c" 前后都是字符 'b',因此找到了一个长度为 3 的回文子字符串 "bcb"。然后向两端延伸一个字符,由于 "bcb" 的前后都是字符 ‘a’,因此又找到一个长度为 5 的回文子字符串 "abcba"。

值得注意的是,回文的长度既可以是奇数,也可以是偶数。长度为奇数的回文的对称中心只有一个字符,而长度为偶数的回文的对称中心有两个字符

代码实现

class Solution {
public:int countPalindrome(string s, int left, int right){int count = 0;while (left >= 0 && right < s.size() && s[left] == s[right]){++count;// 分别向回文的两端延伸一个字符--left;++right;}return count;}
​int countSubstrings(string s) {int totalCount = 0;for (int i = 0; i < s.size(); ++i){totalCount += countPalindrome(s, i, i);totalCount += countPalindrome(s, i, i + 1);}return totalCount;}
};

字符串的下标为 i。第 i 个字符本身可以成为长度为奇数的回文子字符串的对称中心,同时第 i 个字符和第 i + 1 个字符可以一起成为长度为偶数的回文子字符的对称中心。因此在上述代码中,for 循环通过对每个下标调用两次 countPalindrome 来统计回文子字符串的个数

该解法的时间复杂度是 O(n^2),空间复杂度是 O(1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/635842.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【WPF.NET开发】以编程方式打印XPS文件

本文内容 可以使用 AddJob 方法的一个重载来打印 XML 纸张规范 (XPS) 文件&#xff0c;而根本无需打开 PrintDialog 或任何用户界面 (UI)&#xff08;从原理上讲&#xff09;。 还还可以使用多种 XpsDocumentWriter.Write 和 XpsDocumentWriter.WriteAsync 方法打印 XPS 文件…

04--JdbcTemplate模版

1、JdbcTemplate模版 1.1 概述 Spring JDBC Spring框架对JDBC的简单封装。提供了一个JdbcTemplate对象简化JDBC的开发&#xff08;后面专门讲spring框架) 1.2 实现步骤 1. 导入jar包 4 1 2. 创建JdbcTemplate对象。依赖于数据源DataSource JdbcTemplate template new JdbcTe…

【论文阅读 SIGMOD18】Query-based Workload Forecasting for Self-Driving

Query-based Workload Forecasting for Self-Driving Database Management Systems My Summary ABSTRACT Autonomous DBMS的第一步就是能够建模并预测工作负载&#xff0c;以前的预测技术对查询的资源利用率进行建模。然而&#xff0c;当数据库的物理设计和硬件资源发生变化…

Windows如何部署TortoiseSVN客户端

文章目录 前言1. TortoiseSVN 客户端下载安装2. 创建检出文件夹3. 创建与提交文件4. 公网访问测试 前言 TortoiseSVN是一个开源的版本控制系统&#xff0c;它与Apache Subversion&#xff08;SVN&#xff09;集成在一起&#xff0c;提供了一个用户友好的界面&#xff0c;方便用…

Spring第六天(注解开发第三方Bean)

注解开发管理第三方Bean 显然&#xff0c;我们无法在第三方Bean中写入诸如service这样的注解&#xff0c;所以&#xff0c;Spring为我们提供了Bean这一注解来让我们通过注解管理第三方Bean 第二种导入方式由于可读性太低&#xff0c;故只介绍第一种导入方式&#xff0c;这里我…

自动化工具实践操作-注入自定义代码

功能 采集掘金左边每个tab下文章的标题。人为操作就是点击一个tab&#xff0c;复制文字标题&#xff0c;重复以上操作。根据这个&#xff0c;我们可以转换成自己的代码 开始设计 如上文操作基本一致。新建任务、设计点击事件如出一辙。 自定义循环事件 操作循环节点&#…

R语言【cli】——ansi_has_any():检查字符串里是否存在ANSI格式

Package cli version 3.6.0 Usage ansi_has_any(string, sgr TRUE, csi TRUE, link TRUE) Arguments 参数【string】&#xff1a;要检查的字符串。它也可以是字符向量 参数【sgr】&#xff1a;是否查找SGR(样式化)控制序列。 参数【csi】&#xff1a;是否查找非sgr控制序…

ubuntu下常见查看库信息的指令

要查看共享库&#xff08;例如 liblog4cplus.so&#xff09;的信息&#xff0c;可以使用一些工具来获取有关库的详细信息。以下是一些常用的方法&#xff1a; 1. 使用 nm 命令&#xff1a; nm 命令用于显示目标文件或共享库的符号表。你可以运行以下命令查看 liblog4cplus.so…

Mysql:重点且常用的操作和理论知识整理 ^_^

目录 1 基础的命令操作 2 DDL 数据库定义语言 2.1 数据库操作 2.2 数据表操作 2.2.1 创建数据表 2.2.2 修改和删除数据表 2.2.3 添加外键 3 DML 数据库操作语言 3.1 插入语句(INSERT) 3.2 修改语句(UPDATE) 3.3 删除语句 3.3.1 DELETE命令 3.3.2 TRUNCATE命令 4 …

第1周:Day 3 - PyTorch与TensorFlow的异同介绍(入门级)

第1周&#xff1a;Day 3 - PyTorch介绍 学习目标 理解PyTorch的基本概念和主要特点。 成功安装PyTorch环境。 PyTorch简介 PyTorch 是一个开源的机器学习库&#xff0c;广泛用于计算机视觉和自然语言处理等领域。 它由Facebook的人工智能研究团队开发&#xff0c;提供了丰富的A…

idea中使用git提交代码报 Nothing To commit No changes detected

问题描述 在idea中右键&#xff0c;开始将变更的代码进行提交的时候&#xff0c;【Commit Directory】点击提交的时候 报 Nothing To commit No changes detected解决方案 在这里点击Test 看看是不是能下面显示git版本&#xff0c;不行的话 会显示一个 fix的字样&#xff0c;行…

【日常聊聊】边缘计算的挑战和机遇

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a; 日常聊聊 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 边缘计算的挑战和机遇 一&#xff1a;数据安全与隐私保护 二&#xff1a;网络稳定性与可靠性 三&#xff1a;实时性与性能优…

Unity中的协程

定义&#xff1a;协程使得任务的执行可以分配到多个帧中完成&#xff0c;在Unity中&#xff0c;协程从开始执行到第一个yield return 语句后将调用权归还Unity主线程&#xff0c;并在紧随的下一帧继续从上次结束调用的代码上下文位置恢复执行。 常见应用场景&#xff1a;HTTP请…

【Vue】属性计算 computed

<script setup>import { ref,computed} from vue let hbs ref([]); //装爱好的值const publishHbsMessagecomputed(()>{return hbs.value.length>0?Yes:No}) </script><template><div>吃 <input type"checkbox" name"hbs&qu…

C++入门学习(八)sizeof关键字

sizeof 是 C 和 C 中的一个运算符&#xff0c;用于确定特定类型或对象的内存大小&#xff08;以字节为单位&#xff09;。 1、查看数据类型占据内存大小 #include <iostream> using namespace std; int main() {short a 1;int b 1;long c 1;long long d 1;cout<…

Ubuntu使用docker-compose安装chatGPT

ubuntu环境搭建专栏&#x1f517;点击跳转 Ubuntu系统环境搭建&#xff08;十五&#xff09;——使用docker-compose安装chatGPT Welcome to the AI era! 使用docker compose安装 在/usr/local文件夹下创建chatgpt mkdir chatgpt创建docker-compose.yaml vim docker-compos…

代码随想录算法训练营Day32|122.买卖股票的最佳时机 II、55. 跳跃游戏、45.跳跃游戏 II

目录 122.买卖股票的最佳时机 II 前言 思路 算法实现 55. 跳跃游戏 思路 算法实现 45.跳跃游戏 II 前言 思路 算法实现 总结 122.买卖股票的最佳时机 II 题目链接 文章链接 前言 本题要求只能持有一支股票&#xff0c;根据每日股票的价格控制股票的买入和卖出获取最…

6. UE5 RPG AttributeSet的设置

AttributeSet 负责定义和持有属性并且管理属性的变化。开发者可以子类化UAttributeSet。在OwnerActor的构造方法中创建的AttributeSet将会自动注册到ASC。这一步必须在C中完成。 Attributes 是由 FGameplayAttributeData定义的浮点值。 Attributes能够表达从角色的生命值到角色…

文件扫码下载的方法?轻松制作文件活码的技巧

现在多文件生成二维码的需求不断的增多&#xff0c;为什么大家都开始选择这种方式来展示文件呢&#xff1f;一方面是将文件储存在云端&#xff0c;避免有时间限制的问题&#xff0c;随时查看文件&#xff1b;二是可以让其他人同时扫描二维码查看内容&#xff0c;当需要分享给很…

Vue四个阶段,八个钩子函数

- 创造阶段&#xff1a;创建Vue实例和初始化数据事件&#xff0c;数据代理&#xff0c;监测watch - beforeCreate&#xff0c;只是创建实例&#xff0c;不能this.$el,this.msg,this.方法名&#xff08;&#xff09; - created&#xff0c;数据代理了&#xff0c;能v…