首页 > 其他 > 详细

1027A. Palindromic Twist#变形回文串

时间:2018-08-25 21:08:03      阅读:150      评论:0      收藏:0      [点我收藏+]

题目内容:http://codeforces.com/contest/1027/problem/A

题目解析:输入T组字符串,每个字符串都必须改变一次,每个字母改变的规则是变成相邻的字母,字母a只能变b,z只能变y。改变后 的字符依旧是否能够变成回文串,就输出YES,否则就输出NO。注意,相邻的字母并没有固定是左边还右边,所以要考虑分成两种情况,一种本身就是回文串的就输出YES,不是回文串的判断对应位置字符asc码差是否等于2。

#include<iostream>
#include<cmath>
using namespace std;
int main()
{
    int n,t,flag;
    string s;
    cin>>t;
    while(t--)
    {
        flag=0;
        cin>>n>>s;
        for(int i=0; i<n/2; i++)
            if(s[i]!=s[n-i-1]&&abs(s[i]-s[n-i-1])!=2)
            {//用ascll码理解,满足:既不相等且相差非2 
                puts("NO");
                flag=1;
                
                break;
            }
        if(!flag)puts("YES");
    }
    return 0;
}

 

参考出处:https://blog.csdn.net/memory_qianxiao/article/details/81838111

1027A. Palindromic Twist#变形回文串

原文:https://www.cnblogs.com/hello-OK/p/9535224.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!