Palindromes UVa401 字符串

Root :: Problem Set Volumes :: Volume IV     

401 - Palindromes 回文词

我头一回在UVa上写题啊,不知道怎么迅速查询题目。暂时先用这样的格式来标记题目吧。

用字符常量数组来标记镜面字母比较方便啊,这一题提交了4次~  -.-  2次编译错误。 UVa还真是娇气啊。

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <string.h>
using namespace std;
#define LEN 25
char s[LEN];
char self[]="123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char rev[]="1SE*Z**8********A***3**HIL*JM*O***2TUVWXY5";

int main(){
#ifndef ONLINE_JUDGE
	freopen("401in.txt","r",stdin);
#endif
	bool pali_flag,mirror_flag;
	int i,j;
	while (scanf("%s",s)!=EOF){
		pali_flag=true;
		mirror_flag=true;
		for (i=0,j=strlen(s)-1;i<=j;i++,j--){
			if (!pali_flag&&!mirror_flag)
				break;
			if (s[i]!=s[j])
				pali_flag=false;
			if (self[s[i]-49]!=rev[s[j]-49])
				mirror_flag=false;
		}
		if (!pali_flag&&!mirror_flag)
			printf("%s -- is not a palindrome.\n",s);
		else if (pali_flag&&!mirror_flag)
			printf("%s -- is a regular palindrome.\n",s);
		else if (!pali_flag&&mirror_flag)
			printf("%s -- is a mirrored string.\n",s);
		else if (pali_flag&&mirror_flag)
			printf("%s -- is a mirrored palindrome.\n",s);
		cout<<endl;
	}
	return 0;
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值