Assembly Line | ||
Accepted : 63 | Submit : 433 | |
Time Limit : 1000 MS | Memory Limit : 65536 KB |
题目描述胡大加工厂出产一种特殊零件。某天,客户到厂来查看零件。工厂生产的零件有三个质量等级从高到低分别为A、B、C,但是流水线上的零件质量参差不齐。为了给客户留下好的印象,胡大决定把流水线上的零件整理下,最前面既最左边为质量最高的A等级零件,接着为B、C等级的零件。胡大每次可以选择两个零件,互换其位置。为了节省体力,胡大想知道最少的互换次数。 输入第一行是一个整数K,表示样例个数。 每组样例为一个字符串,由字符'A','B','C',组成,长度不超过1000个字符,表示零件的原始顺序。 输出对于每组样例,输出一行,即最少的互换次数。 样例输入2 CBA ABAC 样例输出1 1 SourceXTUCPC2013 |
首先输入的字符串会有如下几种可能:
1.ABC这个顺序为正确的顺序,可以忽视;
2.ACB、BAC、CBA这些都是通过一次交换就可以得到正确的顺序,是因为他们相互占了彼此的位置,只需一次便可恢复;
3.BCA这个就是要通过两次交换才能得出正确的顺序,是因为3者之间的占位成了环,两次交换才可恢复。
那么我们要做的就是找出要交换的1次和交换2次的数量,结果自然就出来了。
代码如下:
#include <iostream>
#include <algorithm>
#include <string.h>
#include <math.h>
using namespace std;
char s[1005] , s1[1005];
int main()
{
int cas;
scanf("%d\n",&cas);
while( cas-- ){
scanf("%s",s);
strcpy( s1 , s );
int len = strlen(s);
sort( s , s+len );
int ans = 0;
int t=0,i,j;
for( i=0 ,j; i<len ; i++ ){
if( s[i] != s1[i] ){
for( j=i+1 ; j<len ; j++ ){
if( s[i]==s1[j] && s[j] == s1[i] ){
s[j] = s1[j];
ans++;
break;
}
}
if( j == len ){
t++; //在后面没有找到对应的,说明不是彼此占了位置
//而是三者成环
}
}
}
ans += (t/3*2); //因为三者成环我们会计算3次,但是只需2次交换
printf("%d\n",ans);
}
return 0;
}