简单回文判断
“回文串”是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串。请写一个程序判断读入的字符串是否是“回文”.输入包含多个测试实例,输入数据的第一行是一个正整数n,表示测试实例的个数,后面紧跟着是n个字符串.如果一个字符串是回文串,则输出"yes",否则输出"no".
sample input:
4
level
abcde
noon
haha
sample output:
yes
no
yes
no
这个程序第一次运行的时候爆CE,当时选的编译环境是c++,然后调成g++就AC了。
c++编译会显示:
这其实来自于头文件的问题,如果想要在标准c++情况下编译通过,头文件改成 #include< string >
然后对于字符串的处理,g++和c++也是有一定的区别的,一个日常的例子就是gcc中gets和puts不能使用,我们可以用fgets来代替gets,fgets常用方式: fgets(a,100,stdin)//stdin表示接收键盘输入。
在c++中我们接收字符串可以使用cin.getline(接收字符串的变量,接收字符个数,结束字符),第三个参数省略是系统自动默认为"\0".
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
bool judge(string str)
{
int begin=0;
int end=str.size()-1;
while(begin<end)
{
if(str[begin]!=str[end]) return false;
begin++;
end--;
}
}
int main()
{
int n;
cin>>n;
while(n--)
{
string str;
cin>>str;
if(judge(str)) cout<<"yes"<<endl;
else cout<<"no"<<endl;
}
return 0;
}