回文数的猜想:“回文串”是一个正读和反读都一样的字符串,请写一个程序判断读入的字符串是是“回文”。

输入格式:

输入包含多个测试实例,输入数据的第一行是一个正整数n,表示测试实例的个数,后面紧跟着是n个字符串。

输出格式:

如果一个字符串是回文串,则输出“yes”,否则输出“no”;

代码如下:

#include<stdio.h>
#include<string.h>
int main(){
    int n,i,j,m;
    char a[50];
    char b[50];
    scanf("%d",&n);     
        while(n--){
        scanf("%s",&a);
        m=strlen(a);
        for(i=0,j=m-1;i<m;i++,j--)
            b[j]=a[i];        //将a[i]逆序存放到b[j]中
        for(i=0;i<m;i++){
            if(b[i]!=a[i])   
            break;          /*如果b[i]一直等于[i],则循环一直退不出来,直到执行到i=m才会退出,所以在循环之外判断输出yes的条件就是当i==m时,除此之外就是输出no;*/
        }
        if(i==m) 
             printf("yes");
        else 
            printf("no");
    }
    return 0;
}

运行截图:

 

更多推荐

C语言——回文串