用C++编写本关任务:在题干所给程序框架的基础上,编写程序,输入一个字符串,判断是否为回文,是回文则输出"Yes",否则输出"No"。 所谓回文是指一个句子从左到右读和从右到左读是完全一样的,例如 "Able was I ere I saw elba","上海自来水来自海上"。 要求:字符串中可以包含空格以及汉字,但没有换行符(即'\n')和回车符(即'\r'),并且忽略英文字符的大小写,限定字符串长度最大为80。
时间: 2023-07-07 11:07:12 浏览: 188
```C++
#include <iostream>
#include <cstring>
#include <cctype> //用于处理英文字符的大小写
using namespace std;
bool is_palindrome(string s) {
int len = s.length();
for (int i = 0; i < len; i++) {
s[i] = tolower(s[i]); //忽略英文字符的大小写
}
int left = 0, right = len - 1;
while (left < right) {
while (!isalnum(s[left])) { //跳过非字母数字字符
left++;
}
while (!isalnum(s[right])) {
right--;
}
if (tolower(s[left]) != tolower(s[right])) { //忽略英文字符的大小写
return false;
}
left++;
right--;
}
return true;
}
int main() {
string s;
getline(cin, s); //输入字符串
if (is_palindrome(s)) {
cout << "Yes" << endl;
} else {
cout << "No" << endl;
}
return 0;
}
```
阅读全文