AMR12D - The Mirror of Galadriel

With water from the stream Galadriel filled the basin to the brim, and breathed on it, and when the water was still again she spoke. 'Here is the Mirror of Galadriel,' she said. 'I have brought you here so that you may look in it, if you will. For this is what your folk would call magic, I believe; though I do not understand clearly what they mean; and they seem also to use the same word of the deceits of the Enemy. But this, if you will, is the magic of Galadriel. Did you not say that you wished to see Elf-magic?' - Galadriel to Frodo and Sam, describing her Mirror.

We call a string S magical if every substring of S appears in Galadriel's Mirror (under lateral inversion). In other words, a magical string is a string where every substring has its reverse in the string.

Given a string S, determine if it is magical or not.


The first line contains T, the number of test cases. The next T lines contain a string each. 


For each test case, output "YES" if the string is magical, and "NO" otherwise.


1 <= T <= 100
1 <= |S| <= 10
S contains only lower-case characters.


Sample Input:

Sample Output:

Notes / Explanation of Sample Input

For the first test case, the list of substrings are : a, b, ab, ba, aba. The reverse of each of these strings is present as a substring of S too.

For the second test case, the list of substring are : a, b, ab. The reverse of "ab", which is "ba" is not present as a substring of the string.

hide comments
satyamkr118: 2020-12-11 14:08:49

Ac in one go!!! :)

manish_thakur: 2020-03-27 12:34:39

easy palindrome!

sandipan2224: 2019-12-23 07:57:44

Palindrome check gets you AC!!

dharmendrak: 2019-01-03 21:08:31

use simple logic

harshit_k007: 2018-12-28 19:55:43

just check string a pallindrome !!!AC

mr_robot_rb01: 2018-07-09 08:36:08

Too weak test cases.

jmr99: 2018-06-23 14:11:54

use reverse func c++.

payal2621: 2018-02-11 14:47:22

check whether its a palindrome ac in one go

ameyanator: 2018-02-03 09:10:20

The constraints of this question makes it adhoc and an stl implementation question.

dragoncode: 2018-01-02 08:30:54

Think simple ;)

Added by:Varun Jalan
Time limit:2s
Source limit:50000B
Memory limit:1536MB
Cluster: Cube (Intel G860)
Languages:All except: ASM64
Resource:Varun Jalan - ICPC Asia regionals, Amritapuri 2012