您的位置:首页 > 其它

1573:基础练习 完美的代价

2018-03-08 15:37 225 查看
Description

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

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

例如mamad

第一次交换 ad : mamda

第二次交换 md : madma

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

Input

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

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

Output

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

否则输出Impossible

Sample Input

5

mamad

Sample Output

3

Source

蓝桥杯

#include <bits/stdc++.h>
using namespace std;
int main()
{
int n,m;
scanf("%d\n",&n);
m=n-1;
char c[8005];
gets(c);
int flag=0;
int cnt=0;
for(int a = 0; a < m; a ++)
{
for(int b = m; b >= a; b --)
{
if(a==b)
{
if(flag==1||n%2==0)
{
printf("Impossible");
return 0;
}
cnt+=n/2-a;
flag=1;
}
else if(c[a]==c[b])
{
for(int k = b; k < m; k++)
{
swap(c[k],c[k+1]);
cnt++;
}
m--;
break;
}
}
}
printf("%d",cnt);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: