`
hellobin
  • 浏览: 66243 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

UVA 401 - Palindromes

    博客分类:
  • UVA
 
阅读更多

 

A regular palindrome is a string of numbers or letters that is the same forward as backward. For example, the string"ABCDEDCBA"is a palindrome because it is the same when the string is read from left to right as when the string is read from right to left.

 


A mirrored string is a string for which when each of the elements of the string is changed to its reverse (if it has a reverse) and the string is read backwards the result is the same as the original string. For example, the string"3AIAE"is a mirrored string because"A"and"I"are their own reverses, and"3"and"E"are each others' reverses.

 


A mirrored palindrome is a string that meets the criteria of a regular palindrome and the criteria of a mirrored string. The string"ATOYOTA"is a mirrored palindrome because if the string is read backwards, the string is the same as the original and because if each of the characters is replaced by its reverse and the result is read backwards, the result is the same as the original string. Of course,"A","T","O", and"Y"are all their own reverses.

 


A list of all valid characters and their reverses is as follows.

 

 

Character Reverse Character Reverse Character Reverse
A A M M Y Y
B   N   Z 5
C   O O 1 1
D   P   2 S
E 3 Q   3 E
F   R   4  
G   S 2 5 Z
H H T T 6  
I I U U 7  
J L V V 8 8
K   W W 9  
L J X X    

 

 


Notethat O (zero) and 0 (the letter) are considered the same character and thereforeONLYthe letter "0" is a valid character.

 

Input

Input consists of strings (one per line) each of which will consist of one to twenty valid characters. There will be no invalid characters in any of the strings. Your program should read to the end of file.

 

Output

For each input string, you should print the string starting in column 1 immediately followed by exactly one of the following strings.

 

 

STRING CRITERIA
"-- is not a palindrome." if the string is not a palindrome and is not a mirrored string
"-- is a regular palindrome." if the string is a palindrome and is not a mirrored string
"-- is a mirrored string." if the string is not a palindrome and is a mirrored string
"-- is a mirrored palindrome." if the string is a palindrome and is a mirrored string

Notethat the output line is to include the-'s and spacing exactly as shown in the table above and demonstrated in the Sample Output below.

In addition, after each output line, you must print an empty line.

 

Sample Input

NOTAPALINDROME 
ISAPALINILAPASI 
2A3MEAS 
ATOYOTA

 

Sample Output

NOTAPALINDROME -- is not a palindrome.
 
ISAPALINILAPASI -- is a regular palindrome.
 
2A3MEAS -- is a mirrored string.
 
ATOYOTA -- is a mirrored palindrome.

 

 

 

#define RUN
#ifdef RUN

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>
#include <string>
#include <iostream>
#include <sstream>
#include <map>
#include <set>
#include <vector>
#include <list>
#include <cctype> 
#include <algorithm>
#include <utility>
#include <math.h>

using namespace std;

#define MAXN 21
int n = 0;
char input[MAXN];

map<char,char> mymap;

void initMap(){

	mymap['A'] = 'A';
	mymap['E'] = '3';
	mymap['H'] = 'H';
	mymap['I'] = 'I';
	mymap['J'] = 'L';
	mymap['L'] = 'J';
	mymap['M'] = 'M';
	mymap['O'] = 'O';
	mymap['S'] = '2';
	mymap['T'] = 'T';
	mymap['U'] = 'U';
	mymap['V'] = 'V';
	mymap['W'] = 'W';
	mymap['X'] = 'X';
	mymap['Y'] = 'Y';
	mymap['Z'] = '5';
	mymap['1'] = '1';
	mymap['2'] = 'S';
	mymap['3'] = 'E';
	mymap['5'] = 'Z';
	mymap['8'] = '8';
}


bool isPalindrome(char* string){
	
	int validLen = strlen(string);
	//printf("validLen = %d\n", validLen);
	for(int i=0; i<=validLen/2; i++){
		if(string[i] != string[validLen-1-i]){
			return false;
		}
	}
	return true;
}

bool isMirrorString(char* string){
	
	char temp[MAXN];
	strcpy(temp, string);
	
	for(int i=0; i<strlen(string); i++){
		map<char,char>::iterator it = mymap.find(string[i]);
		if(it != mymap.end()){
			temp[i] = it->second;
		}
		else{	// We must deal with those chars that we cannot find!
			temp[i] = '?';
		}
	}
	
	for(int i=0; i<strlen(string); i++){
		if(string[i] != temp[strlen(string)-1-i]){
			return false;
		}
	}
	
	return true;
}


int main(){

#ifndef ONLINE_JUDGE
	freopen("401.in", "r", stdin);
	freopen("401.out", "w", stdout);
#endif
	
	memset(input, 0, sizeof(input));
	initMap();
	
	while(scanf("%s", input) != EOF){
		//printf("%s\n", input);
/* 		if(isPalindrome(input)){
			printf("isPalindrome\n");
		}
		else{
			printf("Not Palindrome\n");
		} */
		if(!isPalindrome(input) && !isMirrorString(input)){
			printf("%s%s\n\n", input, " -- is not a palindrome.");
		}
		else if(isPalindrome(input) && !isMirrorString(input)){
			printf("%s%s\n\n", input, " -- is a regular palindrome.");
		}
		else if(!isPalindrome(input) && isMirrorString(input)){
			printf("%s%s\n\n", input, " -- is a mirrored string.");
		}
		else if(isPalindrome(input) && isMirrorString(input)){
			printf("%s%s\n\n", input, " -- is a mirrored palindrome.");
		}
	}
}


#endif



 

分享到:
评论

相关推荐

    UVaOJ-401(Palindromes).zip_401 Palindromes

    标题中的"UVaOJ-401(Palindromes)"表明这是一个关于解决UVa Online Judge(UVa OJ)上编号为401的编程挑战,该挑战的主题是"Palindromes",即回文串。回文串是指一个字符串无论从前读到后还是从后读到前都是相同的,...

    -palindromes-源码.rar

    标题中的“-palindromes-源码.rar”暗示了这个压缩包可能包含了一组与回文相关的编程源代码。回文是指一个可以正读也可反读的字符串,例如“madam”、“racecar”或者数字“12321”。在编程中,处理回文的算法通常...

    CIS-241-Palindromes

    CIS 241回文 CIS 241中的作业4(第2部分)中的第2个 到期日: 2020年10月23日 程序说明: 回文是指向前和向后以相同方式拼写的字符串。 回文症的一些例子是:“雷达”,“可能是我看到的厄尔巴岛”,以及,如果您...

    -palindromes:js中的基本回文程序

    该项目是多年迭代开发和综合社区知识的产物。 它没有强加特定的开发哲学或框架,因此您可以按照自己的方式自由地构建代码。 主页: : 资料来源: : 推特: 快速开始 选择以下选项之一: ...

    python-4.双重回文数 Dual Palindromes-两种进制哦.py

    python-4.双重回文数 Dual Palindromes——两种进制哦.py

    USACO题目Dual Palindromes (dualpal)及代码解析

    Dual Palindromes(dualpal)这道题目尤为有趣,它考察参赛者对回文数的理解、多进制表示的掌握以及C语言文件输入输出的处理能力,还考验算法设计的创新和效率。 首先,让我们来探讨回文数的概念。所谓回文数,就是...

    zoj 1325 Palindromes.md

    zoj 1325 Palindromes.md

    poj 3376 Finding Palindromes.md

    poj 3376 Finding Palindromes.md

    P1217 USACO1.5 回文质数 Prime Palindromes

    P1217 [USACO1.5] 回文质数 Prime Palindromes

    回文数算法

    return (palindromes[beforeIndex - 1], palindromes[beforeIndex]); } } ``` 在这个代码中,我们使用了二分查找算法(`BinarySearch`)来快速定位目标数字周围的回文数。如果目标数字本身就是回文数,我们会返回...

    palindromes:992015年的课堂项目

    在网络浏览器中打开palindromes.html 使用的技术 使用HTML和JavaScript创建 合法的 版权所有(c)2015 Chris Swan和Phillip Shannon 该软件已获得MIT许可。 特此免费授予获得此软件和相关文档文件(“软件”)副本...

    Palindromes:简单的回文解析应用程序,给出了前三个最大的回文

    从提供的文件名"Palindromes-master"来看,这是一个Git仓库的主分支,通常包含源代码、资源文件、构建脚本等。要运行这个项目,我们需要进入项目的根目录,并确保已经安装了Maven,因为"mvn install"是一个Maven命令...

    寻找11-999之间的回文数

    palindromes = [num for num in range(start, end + 1) if is_palindrome(num)] print(f"在{start}到{end}之间找到的回文数有:", palindromes) if __name__ == "__main__": main() ``` 这个程序首先获取用户...

    python判断回文字符串-09-字典的循环遍历之键值对.ev4.rar

    这个`check_palindromes_in_dict`函数会遍历字典的每个键值对,对值调用`is_palindrome`函数进行回文检查,如果发现非回文字符串,就打印出相关信息。 总的来说,Python的字符串操作和字典遍历是编程中常见的基础...

    POI solutions

    - **Palindromes**:回文问题,识别或者构造回文串。 - **Stage II** - **The Right Turn Drivers' Club**:右转弯驾驶员俱乐部问题,可能涉及交通流模拟。 - **Triangles**:三角形问题,与POII中的类似。 - **...

    USACO全部译题

    **1.2.5 Dual Palindromes** - **问题描述**:题目要求寻找同时是两个不同进制下的回文数。 - **算法思想**:可以采用枚举法,结合快速幂运算进行进制转换和回文检查。 ##### 第二部分:进阶级题目解析 **2.1.1 ...

    洛谷 深基 第1部分 语言入门 第4章 循环结构程序设计(2021.02.17).pdf

    - P1217 [USACO1.5]回文质数 Prime Palindromes:这可能涉及判断质数和回文数,循环用于检查数字的性质。 6. **练习题目**: - P5724 【深基 4.习 5】求极差:可能要求计算一组数的最大值和最小值之间的差值,...

    字符串题目记录

    HDU 3948 The Number of Palindromes 该题目要求找出长度^5 的不同回文子串个数。该题目使用后缀数组来解决,先将 S 的逆加在 S 的后面,然后遍历后缀数组,找到所有回文子串的个数。 总结来说,字符串题目记录...

    圆和矩形是否重叠leetcode-Algorithm-Notes:关于Leetcode、Lintcode编码问题的注意事项

    palindromes that can be built */ int longestPalindrome (string & s) { int result = 0 ; bool hasOdd = false ; std::unordered_map&lt; char , int &gt; count; for ( char ch: s) { ++count[ch]; } for (std::...

    USACO官网93题fps格式 OJ题库

    9 [1.2] 双重回文数 Dual Palindromes 10 [1.3] 混合牛奶 Mixing Milk 11 [1.3] 修理牛棚 Barn Repair 12 [1.3] 牛式 Prime Cryptarithm 13 [1.3] 虫洞 wormhole 14 [1.3] 滑雪课程设计Ski Course Design

Global site tag (gtag.js) - Google Analytics