计蒜客T3364 蒜头君的回文串(C++语言实现)

【题目描述】回文串,是指顺着读和倒着读顺序一样的字符串,比如说abccba就是一个回文串。而abc不是回文串,因为abc倒着读是cba。在这里,我们只考虑字母和数字,比如说abccb a,为一个回文串(因为我们忽略了 和空格),同时,我们忽略大小写,比如说Aba,我们也认为它是一个回文串。现在蒜头君有一个字符串,需要聪明的你帮忙判断这个字符串是不是回文串。

【输入格式】输入一个字符串s,长度为n。

【输出格式】如果字符串s为回文串,输出true,否则输出false。

【C语言实现】

cpp 复制代码
# include <iostream>
int main()
{
    std::string s; // 输入字符串s
//    std::cin >> s; // 这个行不通,因为遇到空格就停止输入了
    getline(std::cin, s); // 这样可以读包含空格的字符串
//     std::cout << "s = " << s << std::endl;
    
    std::string r; // 字符串r中只含有小写字母和数字
    for (int i = 0; i < s.length(); ++i) {
        if (isdigit(s[i]) || islower(s[i])) { // 数字或者小写字母是符合要求的
            r.push_back(s[i]); // 插入到字符串r
        } else if (isupper(s[i])) { // 大写字母要转成对应的小写字母
            r.push_back(s[i] + 32); // 插入到字符串r
        }
    }
    
    int flg = 1; // flg标记是否是回文串,初始值为1
    for (int i = 0, j = r.length() - 1; i < j; ++i, --j) { // 左右两侧双指针移动
        if (r[i] != r[j]) { // 不相等,一定不是回文串
            flg = 0; // 修改flg标记为0
            break; // 退出循环
        }
    }
    if (flg) { // 是回文串,输出true
        std::cout << "true";
    } else { // 不是回文串,输出false
        std::cout << "false";
    }
    return 0;
}
相关推荐
浅川.258 分钟前
回型矩阵(板子题)
c++·矩阵
誰能久伴不乏9 分钟前
Qt 启动时序与事件循环:为什么监控启动不要放在构造函数里,以及 `QTimer::singleShot(0, ...)` 到底做了什么
c语言·c++·qt
ajole21 分钟前
C++学习笔记——stack和queue
开发语言·数据结构·c++·笔记·学习·stl·学习方法
晨非辰31 分钟前
Linux文件操作实战:压缩/传输/计算10分钟速成,掌握核心命令组合与Shell内核交互秘籍
linux·运维·服务器·c++·人工智能·python·交互
MSTcheng.32 分钟前
【C++】使用哈希表封装unordered_set和unordered_map!
c++·哈希算法·散列表·map/set封装
努力努力再努力wz2 小时前
【Linux网络系列】:JSON+HTTP,用C++手搓一个web计算器服务器!
java·linux·运维·服务器·c语言·数据结构·c++
D_evil__9 小时前
【Effective Modern C++】第二章 auto:6. 当auto推导的类型不符合要求时,使用显式类型初始化习惯用法
c++
哈哈不让取名字9 小时前
基于C++的爬虫框架
开发语言·c++·算法
剑锋所指,所向披靡!11 小时前
C++之类模版
java·jvm·c++
C+-C资深大佬12 小时前
C++风格的命名转换
开发语言·c++