博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ny495 少年 DXH
阅读量:7227 次
发布时间:2019-06-29

本文共 1790 字,大约阅读时间需要 5 分钟。

少年 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 右侧添加最少的字符形成的回文串。
样例输入
5addcigartragicdxhisgirlacabaabczyxyz
样例输出
addacigartragicdxhisgirlrigsihxdacabacaabczyxyzcba
讲解:解决本题,要首先考虑前面是否有回文串的情况:
代码如下:
1     #include
2 #include
3 int main() 4 { 5 int x,t,i,n,min,max,k,a,b; 6 char s[102]; 7 scanf("%d",&t); 8 getchar(); 9 while(t--)10 { 11 k=0;12 gets(s);13 x=strlen(s);n=x-1;14 for(i=0;i
=min;min++,max--)20 {21 if(s[min]==s[max])//如果是回文串则k=1;22 k=1;23 else24 { k=2;break;}//如果不是跳出本循环,寻找下一个,和末尾字符相同的字符,再次判断;25 }26 }27 if(k==1) //如果满足条件,即跳出循环,并记录下起始位置,如果没有回文串28 break;29 }30 for(i=0;i
=0;i--)33 printf("%c",s[i]);//然后从回文串的起始位置,倒序输出:34 puts("");35 }36 return 0;37 }

 

转载于:https://www.cnblogs.com/lovychen/p/3187209.html

你可能感兴趣的文章
简易sqlhelper-java
查看>>
通过案例对SparkStreaming 透彻理解三板斧之一:解密SparkStreaming运行机制
查看>>
HBuilder 学习笔记
查看>>
利用OpenStreetMap(OSM)数据搭建一个地图服务
查看>>
TopN算法与排行榜
查看>>
lucene排序算法之向量空间模型(一)
查看>>
新浪微博数据Json格式解析
查看>>
WLAN 802.11 wifl区别
查看>>
oracle授权动态视图权限给用户
查看>>
Debian – 出现-bash: pip: command not found错误解决办法
查看>>
Zxing扫描二维码
查看>>
我的友情链接
查看>>
aspcms后台拿shell漏洞(非添加模块)及修复方法
查看>>
C语言冒泡排序法
查看>>
B2B行业门户网站群发邮件时间及发送频率
查看>>
关于虚拟机能ping通物理机,而物理机ping不通虚拟机问题解决。
查看>>
同台机器启动多个mysql
查看>>
iframe 跨域高度自适应
查看>>
struts2+hibernate3+spring3(ssh2)框架下的web应用
查看>>
Linux下的三个时间属性
查看>>