知识点:无穷大的定义0x3f3f3f3f
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
#include
#include
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;
}
下一篇:AI数字人软件系统开发流程