UVa 401 回文词

/*

* 解题思路:

*这道题题意不难理解、就四种情况。搞了一个下午才AC,我用 C 写的 ,为了判断英文字符还是数字字符,用了一个函数isalpha( char c ),

*       这个函数是在#include<cytpe.h>中,不知道为什么那样判断有问题,所以一直过不了,换成通俗的 if() 判断一下就AC了,

*/

#include <stdio.h>
#include <string.h>
#define A 50
int main( )
{
    char ss[ A ] = { 'A',' ' ,' ' ,' ' , '3', ' ', ' ', 'H','I','L',' ', 'J','M',' ', 'O', ' ', ' ',  ' ', '2', 'T','U','V','W','X','Y','5','1','S','E',' ', 'Z',' ', ' ', '8', ' '};
    char str[ 100 ];
    int i,j;
    int len;
    int flag1,flag2,flag3;

    while( ~scanf("%s",str) )
    {
        flag1 = flag2 = 1;
        len = strlen( str );
        for( i=0,j=len-1; i<=len/2 ; i++,j-- )
        {
            if( flag1 )
                if( str[ i ] != str[ j ] )
                    flag1 = 0;
            if( flag2 )
            {
                flag3 = 0;
                if( str[ i ] >='A' && str[ i ] <='Z' )
                    flag3 = 1;
                if( flag3 == 1 ) flag3 =  str[ i ]-'A';
                else flag3 = 26 + str[ i ]-'1';
                if( str[ j ] != ss[ flag3 ] || ss[ flag3 ] ==' ' )
                    flag2 = 0;
            }
            if( !flag1 && !flag2 ) break;
        }
        if( flag1 && flag2 ) printf("%s -- is a mirrored palindrome.\n\n",str);
        else if( flag1 && !flag2  ) printf("%s -- is a regular palindrome.\n\n",str );
        else if( !flag1 && flag2  ) printf("%s -- is a mirrored string.\n\n",str);
        else if( !flag1 && !flag2 ) printf("%s -- is not a palindrome.\n\n",str);
    }
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值