编写程序测试用户输入的英文字符串是不是回文。忽略所有的空格的标点符号,并忽略字母的大写和小写形式。下面是回文的一些例子:
Able was I ere I saw Elba.
Madam, I’m Adam.
A man, a plan, a canal, Panama.
Racecar
I Love Me, Vol. I.
示例1:
Enter a candidate for palindrome test:
racecar
"racecar" is a palindrome.
示例2:
Enter a candidate for palindrome test:
A man, a plan, a canal, panama.
"A man, a plan, a canal, panama." is a palindrome.
示例3:
Enter a candidate for palindrome test:
Am I a palindrome?
"Am I a palindrome?" is not a palindrome.
参考程序模板:
#include <iostream>
using namespace std;
bool is_pal(const string &s);
//测试字符串s是否是回文,返回真或假
string remove_punct(const string &s, const string &punct);
//将出现在punct中的标点符号从s中删除。
//string s 是可能带标点符号的原始英文字符串,string punct 是所有标点符号构成的字符串
//返回没有标点的字符串
string make_lower(const string &s);
//将字符串s转换为小写形式
//返回字符串s的小写形式的新字符串
string reverse(const string &s);
//将字符串反转
//返回反转后的新字符串
int main()
{
string str;
cout<<"Enter a candidate for palindrome test:"<<endl;
//todo 读入可能带空格的英文句子str, str非空
if(is_pal(str))
cout<<"\""<<str<<"\" is a palindrome.";
else
cout<<"\""<<str<<"\" is not a palindrome.";
return 0;
}
bool is_pal(const string &s)
{
string punct(",;:.?!'’\" "); //包含一个空格的标点符号字符串
//todo 调用remove_punct()删除s中的标点符号
//todo 调用make_lower()求小写形式
//todo 调用reverse()求小写形式的反转字符串
if( /*反转前后字符串相等*/)
return true;
else
return false;
}
string remove_punct(const string &s, const string &punct)
{
string no_punct_s(s);
int pos = 0;
while( /* 条件: 如果在字符串no_punct_s中找到punct中的任意一个标点符号*/ )
{
//todo 从no_punct_s中删除这个标点符号;
}
return no_punct_s;
}
string make_lower(const string &s)
{
string lower_str(s);
//todo
return lower_str;
}
string reverse(const string &s)
{
string reverse_str(s);
//todo
return reverse_str;
}
这个删除标点和空格怎么做啊,求解