本关任务:在题干所给程序框架的基础上,编写程序,输入一个字符串,判断是否为回文,是回文则输出"Yes",否则输出"No"。 所谓回文是指一个句子从左到右读和从右到左读是完全一样的,例如 "Able was I ere I saw elba","上海自来水来自海上"。 要求:字符串中可以包含空格以及汉字,但没有换行符(即'\n')和回车符(即'\r'),并且忽略英文字符的大小写,限定字符串长度最大为80。用c++
时间: 2023-07-07 11:07:45 浏览: 112
```c++
#include <iostream>
#include <cstring>
#include <cctype>
using namespace std;
int main() {
char str[81];
cin.getline(str, 81); // 读入字符串
int len = strlen(str);
bool isPalindrome = true;
for(int i = 0; i < len/2; i++) {
// 将英文字符转为小写,忽略大小写
char c1 = isalpha(str[i]) ? tolower(str[i]) : str[i];
char c2 = isalpha(str[len-1-i]) ? tolower(str[len-1-i]) : str[len-1-i];
if(c1 != c2) {
isPalindrome = false;
break;
}
}
if(isPalindrome) cout << "Yes";
else cout << "No";
return 0;
}
```
相关问题
本关任务:在题干所给程序框架的基础上,编写程序,输入一个字符串,判断是否为回文,是回文则输出"Yes",否则输出"No"。
好的,以下是代码实现:
```python
# 定义一个函数,判断字符串是否为回文
def is_palindrome(s):
if s == s[::-1]: # 如果字符串翻转后与原字符串相等,则为回文
return True
else:
return False
# 输入一个字符串
s = input("请输入一个字符串:")
# 调用函数判断字符串是否为回文
if is_palindrome(s):
print("Yes")
else:
print("No")
```
运行程序后,输入任意一个字符串,程序将会输出该字符串是否为回文。
用C++编写本关任务:在题干所给程序框架的基础上,编写程序,输入一个字符串,判断是否为回文,是回文则输出"Yes",否则输出"No"。 所谓回文是指一个句子从左到右读和从右到左读是完全一样的,例如 "Able was I ere I saw elba","上海自来水来自海上"。 要求:字符串中可以包含空格以及汉字,但没有换行符(即'\n')和回车符(即'\r'),并且忽略英文字符的大小写,限定字符串长度最大为80。
```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;
}
```
阅读全文