nyoj 495 少年 DXH

少年 DXH

时间限制: 1000 ms  |  内存限制: 65535 KB
难度: 2
描述
大家都知道,DXH 幼时性格怪癖,小朋友都不喜欢和他玩,这种情况一直到 DXH 的少年时期也没有改变。
少年时期的 DXH 迷上了"回文串",“回文串”是指正着读倒着读都一样的字符串。DXH一个人的时候喜欢在地上随便写一个字符串 S,然后在这个字符串的右边添加尽量少的字符(可以不添加,就是 0 个),使得这个字符串变成“回文串”。但玩的时间长了,DXH 的手也酸了,聪明的你能帮他写一个程序,算出这个添加最少字符形成的回文串吗?
一个字符串 S[1..L]被称为回文串,当且仅当 S[i] = S[L - i + 1] (1 <= i <= L)。
输入
第一行,一个 T (T <= 100),表示有 T 个字符串需要你判断
之后 T 行,每行一个字符串 S。
S 的长度|S|满足 1 <= |S| <= 50,且 S 只由小写字母'a' -'z'组成。
输出
对于每个字符串,输出一行,每行一个字符串 S', 是在 S 右侧添加最少的字符形成的回文串。
样例输入
5
add
cigartragic
dxhisgirl
acaba
abczyxyz
样例输出
adda
cigartragic
dxhisgirlrigsihxd
acabaca

abczyxyzcba


就拿样例  acabaca 举例吧

acabaca_ _ _ ......

_ _ _ .....acabaca

经过分析可知,当原来的字符串从任意位置到最后一个位置并且经过反转的字符串从第一个到任意一个一一对应时

经过反转的字符串剩下的字符即为答案

#include <map>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define INF 0x3f3f3f
using namespace std;

char s1[55];
char s2[55];

int main(){
    int i,j,k,t,f,len,flag;
    scanf("%d",&t);
    while(t--){
        scanf("%s",s1);
        len=strlen(s1);
        for(i=0,j=len-1;i<len;i++,j--)
            s2[j]=s1[i];
        for(i=0;i<len;i++){
                k=i;
            for(j=0;j<len;j++){
                if(s1[k]==s2[j])
                    k++;
                else
                    break;
            }
            if(k==len){
                f=j;
                break;
            }
        }
        printf("%s",s1);
        for(i=f;i<len;i++)
            printf("%c",s2[i]);
        printf("\n");
    }
    return 0;
}


你可能感兴趣的:(nyoj 495 少年 DXH)