/*------------------------------------------------------ 注意:仅在标有"Begin"和"End"的注释行之间补充填写代码, 请勿改动任何已有内容。 ------------------------------------------------------*/ #include <iostream> using namespace std; #define STR_LEN 80 //读入一行存入字符数组str,长度不超过maxLength void readline(char str[], int maxLength); //判断字符串str是否是回文 bool isPalindrome(char str[]); int main() { char str[STR_LEN + 1]; // cout << "Please input a string with length <= " << STR_LEN << ":"; readline(str, STR_LEN); if (isPalindrome(str)) { cout << "Yes" << endl; } else { cout << "No" << endl; } return 0; } //读入一行存入字符数组str,长度不超过maxLength void readline(char str[], int maxLength) { int i = 0; while (i < maxLength) { char ch = cin.get(); if (ch != '\n' && ch != '\r') { str[i] = ch; } else { break; } i++; } str[i] = '\0'; } //判断字符串str是否是回文 bool isPalindrome(char str[]) { /********* Begin *********/ int pos; for (int i=0;i<80;i++) { if (str[i] <='Z' && str[i]>='A') {
时间: 2025-05-21 21:34:03 浏览: 18
### C++ 中实现判断字符串是否为回文的函数
为了在 C++ 中编写一个能够检查字符串是否是回文的函数,可以采用双指针方法。这种方法通过两个指针分别从字符串两端向中间移动并比较字符来完成验证过程。以下是具体实现:
#### 实现细节
1. **去除无关字符**:忽略非字母和数字字符。
2. **统一大小写**:将所有大写字母转换成小写字母以便于比较。
3. **双指针法**:定义两个指针 `left` 和 `right`,分别指向字符串开头和结尾。逐步向中心靠拢,逐个比较对应位置上的字符。
下面是基于以上逻辑编写的完整代码示例:
```cpp
#include <iostream>
#include <cctype> // 提供 isalnum 和 tolower 函数支持[^5]
bool isPalindrome(const std::string& s) {
int left = 0;
int right = static_cast<int>(s.length()) - 1;
while (left < right) {
// 跳过非字母数字字符
while (left < right && !std::isalnum(static_cast<unsigned char>(s[left]))) {
++left;
}
while (left < right && !std::isalnum(static_cast<unsigned char>(s[right]))) {
--right;
}
// 比较当前字符(忽略大小写)
if (std::tolower(static_cast<unsigned char>(s[left])) !=
std::tolower(static_cast<unsigned char>(s[right]))) {
return false; // 如果不匹配,则返回false
}
++left;
--right;
}
return true; // 若全部匹配成功则返回true
}
int main() {
std::string input;
std::cout << "请输入要检测的字符串:" << std::endl;
std::getline(std::cin, input);
if (isPalindrome(input)) {
std::cout << "该字符串是回文!" << std::endl;
} else {
std::cout << "该字符串不是回文!" << std::endl;
}
return 0;
}
```
#### 关键点解释
- 使用 `<cctype>` 库中的 `isalnum()` 来过滤掉非字母数字字符[^5]。
- 将字符转为小写后再做比较以确保忽略大小写差异[^5]。
- 双指针技术有效减少了不必要的循环次数,提升了效率[^3]。
---
###
阅读全文
相关推荐

















