zoukankan      html  css  js  c++  java
  • ny495 少年 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
    讲解:解决本题,要首先考虑前面是否有回文串的情况:
    代码如下:
     1     #include<stdio.h>
     2     #include<string.h>
     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<x;i++)
    15                       {
    16                             if(s[i]==s[n])//先判断前面是否有回文串,有的话记录回文串开始的位置a
    17                      {
    18                             a=min=i;b=max=n;
    19                     for(;max>=min;min++,max--)
    20                           {
    21                                 if(s[min]==s[max])//如果是回文串则k=1;
    22                                          k=1;
    23                                 else
    24                                 { k=2;break;}//如果不是跳出本循环,寻找下一个,和末尾字符相同的字符,再次判断;
    25                            }
    26                        }
    27                           if(k==1)       //如果满足条件,即跳出循环,并记录下起始位置,如果没有回文串
    28                     break;
    29                             }
    30                        for(i=0;i<x-1;i++)
    31                                 printf("%c",s[i]);//先输出以前的字符串,最后一个不输出;在下面输出,因为只输出一个
    32                       for(i=a;i>=0;i--)
    33                              printf("%c",s[i]);//然后从回文串的起始位置,倒序输出:
    34                     puts("");
    35               }
    36         return 0;
    37     }
  • 相关阅读:
    IOS开发C语言入门如何结合Terminal和Vim开发C语言程序
    如何开发原生的 JavaScript 插件(知识点+写法)
    IOS开发数据持久化篇之文件存储(一)
    PC 端微信扫码注册和登录
    2020最全面的微服务
    RabbitMQ详解
    MongoDB基础篇&集群篇
    从原理上理解MySQL的优化建议
    分布式日志搜集ELK
    MySQL高级篇性能优化
  • 原文地址:https://www.cnblogs.com/lovychen/p/3187209.html
Copyright © 2011-2022 走看看