XTU 1150 Assembly Line
来源:互联网 发布:新淘宝店铺开了没人买 编辑:程序博客网 时间:2024/05/01 15:05
Assembly Line
Accepted : 63 Submit : 433Time Limit : 1000 MS Memory Limit : 65536 KB题目描述
胡大加工厂出产一种特殊零件。某天,客户到厂来查看零件。工厂生产的零件有三个质量等级从高到低分别为A、B、C,但是流水线上的零件质量参差不齐。为了给客户留下好的印象,胡大决定把流水线上的零件整理下,最前面既最左边为质量最高的A等级零件,接着为B、C等级的零件。胡大每次可以选择两个零件,互换其位置。为了节省体力,胡大想知道最少的互换次数。
输入
第一行是一个整数K,表示样例个数。 每组样例为一个字符串,由字符'A','B','C',组成,长度不超过1000个字符,表示零件的原始顺序。
输出
对于每组样例,输出一行,即最少的互换次数。
样例输入
2CBAABAC
样例输出
11
Source
XTUCPC2013
首先输入的字符串会有如下几种可能:
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;}
- XTU 1150 Assembly Line
- Assembly line / Pipeline
- XTU1150:Assembly Line
- 湘潭大学 1150 Assembly Line ABC移动问题
- Assembly-Line scheduling------code in c++
- Assembly-Line Schedule----code in c style
- DP34 流水线调度问题 Assembly Line Scheduling @geeksforgeeks
- 文章标题 CSU 1846: Assembly line(DP)
- Assembly
- Assembly
- assembly
- goodbye, XTU
- XTU 1140
- XTU OJ
- XTU OJ
- XTU 1185
- xtu 4
- xtu 8
- C++实现最小堆(binary heap)
- 常用 Java 静态代码分析工具的分析与比较
- cocos2dx-mac下 cocos2dx 移植到android平台
- 1048. Find Coins (25)
- 学习:java设计模式—Iterator模式
- XTU 1150 Assembly Line
- 通信相关经典书籍
- 1001. A+B Format (20)
- 局域网工具的工作流程
- 学习:java设计模式—工厂模式
- html5 w3C 下载地址
- 一个简单的python爬虫程序
- 1002. A+B for Polynomials (25)
- 数学之美番外篇:平凡而又神奇的贝叶斯方法