您的位置:首页 > 其它

蓝桥杯 完美的代价

2014-03-20 18:23 197 查看

题目描述

  回文串,是一种特殊的字符串,它从左往右读和从右往左读是一样的。小龙龙认为回文串才是完美的。现在给你一个串,它不一定是回文的,请你计算最少的交换次数使得该串变成一个完美的回文串。

  交换的定义是:交换两个相邻的字符

  例如mamad

  第一次交换 ad : mamda

  第二次交换 md : madma

  第三次交换 ma : madam (回文!完美!)

输入格式

  第一行是一个整数N,表示接下来的字符串的长度(N <= 8000)

  第二行是一个字符串,长度为N.只包含小写字母

输出

  如果可能,输出最少的交换次数。

  否则输出Impossible

样例输入

5

mamad

样例输出

3

#include<iostream>
#include<string.h>
#include<stdio.h>
using namespace std;
int main()
{
int n,i,j,k,f,p,r,w,res=0;
char s[8005];
cin>>n;
cin>>s;
f=0;
for(i=0,j=n-1; i<j; i++,j--)
{
p=-1;
for(r=j;r>i;r--)
{
if(s[r]==s[i])
{
for(w=r;w<j;w++)
s[w]=s[w+1];
p=j-r;
break;
}
}
if(p==-1)
{
if(n%2==1 && !f)
{
f=1;
res=res+n/2-i;
j++;
}
else
{
res=-1;
break;
}
}
else
res=res+p;
}
if(res==-1)
printf("Impossible\n");
else
printf("%d\n",res);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: