知识点:无穷大的定义0x3f3f3f3f
为什么无穷大总是0x3f3f3f3f而不是0x7fffffff?
题目:
IT产业人才需求节节攀升。业内巨头百度、阿里巴巴、腾讯(简称BAT)在某海滩进行招聘活动。
招聘部门一字排开。由于是自由抢占席位,三大公司的席位随机交错在一起,形如:
ABABTATT,这使得应聘者十分别扭。
于是,管理部门要求招聘方进行必要的交换位置,使得每个集团的席位都挨在一起。即最后形如:
BBAAATTT 这样的形状,当然,也可能是:
AAABBTTT 等。
现在,假设每次只能交换2个席位,并且知道现在的席位分布,
你的任务是计算:要使每个集团的招聘席位都挨在一起需要至少进行多少次交换动作。
输入:
输入是一行n个字符(只含有字母B、A或T),表示现在的席位分布。
n<=104
输出:
输出是一个整数,表示至少交换次数。
思路:
暴力:6种排列方式
宏观可分为3个区A\B\C
交换次数=A区非A个数+B区C的个数+B区A的个数-min(A区B的个数,B区A的个数)
然后比较6种排列中,交换次数最小的是几次
代码:
#include<iostream>
#include<algorithm>
#include<queue>
using namespace std;
string str;
int mn = 0x3f3f3f3f;//定义一个无穷大
char t[6][4] = { "ABT", "ATB", "BAT","BTA","TAB","TBA"};
int changes(char A, char B, char C) {
int a=0, b=0, c=0,num=0,numb=0,numa=0,numc=0;
for (int i = 0; i < str.length(); i++) {
if (str[i] == A)
a++;
else if (str[i] == B)
b++;
else if (str[i] == C)
c++;
}
for (int i = 0; i < a; i++) {
if (str[i] != A)
num++;
if (str[i] == B)
numb++;
}
for (int i = a; i < a + b; i++) {
if (str[i] == A)
numa++;
if (str[i] == C)
numc++;
}
num += numa + numc - min(numa,numb);
return num;
}
int main() {
cin >> str;
for (int i = 0; i < 6; i++) {
mn = min(mn, changes(t[i][0], t[i][1], t[i][2]));
}
cout << mn << endl;
return 0;
}