CUMT JUGS

来源:互联网 发布:泯然众人 知乎 编辑:程序博客网 时间:2024/06/06 15:44

在学校oj上做了一道比较有意思的题目,题目很长,大概说一说意思吧:有A和B两个杯子,保证A的容积不大于B的容积,现在给出一个目标容量N升的水,问经过AB两个杯子怎样勾兑,最后可以在B容器中调出N升的水。其中的约束条件如下:

0 < A <= B and N <= B <=1000 ,并且假设一定能够勾兑出想要的结果。问勾兑的过程具体是怎么样的;并举下面的例子:

Sample Input

3 5 4
5 7 3

Sample Output

fill B
pour B A
empty A
pour B A
fill B
pour B A
success
fill A
pour A B
fill A
pour A B
empty B
pour A B
success
pour B A表示把B中的水倒到A中,能倒满则倒满,如果B中还有剩余,则empty B表示清空。刚开始拿到题目一脸懵X,但后来发现分析了一遍之后发现规律了,如果N满足(N>A)则一直以B杯为那只fill的杯子,一直将B中的水倒到A中,重复这个过程一直到B中水等于N为止,反之则以A杯为那只一直fill的杯子,直到B中的水为N为止,最后结果输出success。代码如下:

#include<iostream>using namespace std;int main(){int Ca,Cb,N;while(cin>>Ca>>Cb>>N){int a ,b ;int aa =0;int bb = 0;if(N==Ca){cout<<"fill A"<<endl;cout<<"pour A B"<<endl;cout<<"success"<<endl;}else if(N==Cb){cout<<"fill B"<<endl;cout<<"success"<<endl;}else if(N>Ca)     {while(bb!=N){if(bb==0){cout<<"fill B"<<endl;bb=Cb;}if(aa==Ca){cout<<"empty A"<<endl;aa=0;}else if(bb+aa<=Ca){cout<<"pour B A"<<endl;aa+=bb;bb=0;}else {cout<<"pour B A"<<endl;bb-=Ca-aa;aa=Ca;}}cout<<"success"<<endl;}else{while(bb!=N){if(aa==0){cout<<"fill A"<<endl;aa=Ca; }if(bb==Cb){cout<<"empty B"<<endl;bb=0;}else if(bb+aa<=Cb){cout<<"pour A B"<<endl;bb+=aa;aa=0;}else{cout<<"pour A B"<<endl;aa-=Cb-bb;bb=Cb;}}cout<<"success"<<endl;}}return 0; } 


0 0