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
来源
山东大学 ACM/ICPC 校赛高年级组试题 2012
上传者
ACM_李如兵

ac代码

#include<stdio.h>
#include<string.h>
int fun(char *s)
{
	int len=strlen(s);
	int i,j=len-1,k;
	for(i=0;i<j;i++,j--)
	{
		if(s[i]!=s[j])
			return 0;
	}
	return 1;
}
int main()
{
	int n;
	scanf("%d",&n);
	while(n--)
	{
		char s[500];
		int len,i,j,k;
		scanf("%s",s);
		len=strlen(s);
		//j=len-1;
		if(fun(s))
		{
			printf("%s\n",s);
			continue;
		}
		for(i=0;i<len;i++)
		{
			k=len;
			for(j=i;j>=0;j--)
			{
				s[k++]=s[j];
				s[k]='\0';	
			}if(fun(s))
					break;
		}
		printf("%s\n",s);
	}
}


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值