0

0

c++中如何判断一个字符串是否为回文_c++回文串判断算法实现【详解】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-17 16:37:02

|

483人浏览过

|

来源于php中文网

原创

c++kquote>推荐用双指针法:left从首、right从尾向中间遍历比较字符,时间O(n/2)、空间O(1);空串和单字符返回true;忽略大小写时统一转小写;默认全字符参与比较。

c++中如何判断一个字符串是否为回文_c++回文串判断算法实现【详解】

std::string 双指针判断回文串(推荐)

最直接、高效且无额外空间开销的方式是用两个索引从首尾向中间逼近,逐字符比较。C++ 标准库std::string 支持随机访问,operator[] 时间复杂度为 O(1),整个过程只需 O(n/2) 次比较。

注意点:

  • 空字符串 "" 和单字符如 "a" 都算回文,逻辑上应返回 true
  • 需处理大小写:若题目要求忽略大小写,建议统一转小写(用 std::tolower 逐字符转换,别用 std::transform + std::toupper 混用)
  • 不跳过非字母数字字符——除非题目明确要求“只比对字母数字”,否则默认全字符参与比较
bool isPalindrome(const std::string& s) {
    int left = 0, right = s.length() - 1;
    while (left < right) {
        if (s[left] != s[right]) return false;
        ++left;
        --right;
    }
    return true;
}

遇到大小写/标点干扰时怎么预处理?

如果输入含空格、逗号、大小写混杂(例如 "A man a plan a canal Panama"),不能直接双指针硬比。必须先提取有效字符并归一化。但不要新建字符串再反转比较——看似简洁,实则多一次 O(n) 内存分配和 O(n) 复制,还可能触发短字符串优化以外的堆分配。

更稳妥的做法是边遍历边过滤+转换,在双指针内跳过无效字符:

立即学习C++免费学习笔记(深入)”;

  • std::isalnum(c) 判断是否为字母或数字
  • std::tolower(c) 统一小写(注意:参数是 unsigned char 或 EOF,传入 char 时需先转成 unsigned char 防止符号扩展出错)
  • 避免在循环中反复调用 s.length(),它虽是 O(1),但编译器未必总优化掉
bool isPalindrome(const std::string& s) {
    int left = 0, right = s.size() - 1;
    while (left < right) {
        while (left < right && !std::isalnum(static_cast(s[left]))) ++left;
        while (left < right && !std::isalnum(static_cast(s[right]))) --right;
        if (std::tolower(static_cast(s[left])) 
            != std::tolower(static_cast(s[right]))) {
            return false;
        }
        ++left;
        --right;
    }
    return true;
}

std::equal + reverse_iterator 是否更“C++”?

可以,但要注意适用边界。写法简洁:

Text-To-Song
Text-To-Song

免费的实时语音转换器和调制器

下载
bool isPalindrome(const std::string& s) {
    return std::equal(s.begin(), s.end(), s.rbegin());
}

这行代码语义清晰,底层也是双指针逻辑,性能与手写相当。但它隐含一个前提:你信任 std::equalreverse_iterator 的实现不会引入额外开销——实际上现代 STL(libstdc++ / libc++)都做了优化,没问题。

不过,这个写法无法自然融入「跳过非字母数字」的需求。一旦要过滤,就得先构造新字符串,失去原地判断优势。所以它适合干净输入场景;带清洗逻辑时,还是显式双指针更可控。

为什么不用 std::string::compare 或反转后比较?

有人会写 s == std::string(s.rbegin(), s.rend()),这会触发一次完整字符串拷贝和构造,空间复杂度升为 O(n),且至少两次遍历(构造 + 比较)。在嵌入式或高频调用场景下,这种写法容易成为瓶颈。

std::string::compare 本身不提供反向比较接口,强行用它只会让代码更绕,无实际收益。

真正容易被忽略的是:当字符串含 Unicode(如中文、emoji)时,上述所有基于 char 的方案都会失效——因为 UTF-8 下一个字符可能占多个字节std::string 是字节容器,不是字符容器。此时必须先做 UTF-8 解码,用 std::u32string 或第三方库(如 ICU、utf8cpp)处理。普通算法题通常不考虑这点,但真实项目里,如果需求文档写着“支持中文回文”,那就不能只跑通 "上海海上" 这种测试用例了。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

317

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

257

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

208

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1465

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

619

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

550

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

545

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

161

2025.07.29

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.6万人学习

Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号