• 2019 GDUT Rating Contest I : Problem H. Mixing Milk


    题面:

    H. Mixing Milk

    Input file: standard input
    Output file: standard output
    Time limit: 1 second
    Memory limit: 256 megabytes
     
    Farming is competitive business – particularly milk production. Farmer John figures that if he doesn’t innovate in his milk production methods, his dairy business could get creamed! Fortunately, Farmer John has a good idea. His three prize dairy cows Bessie, Elsie, and Mildred each produce milk with a slightly different taste, and he plans to mix these together to get the perfect blend of flavors.

    To mix the three different milks, he takes three buckets containing milk from the three cows. The buckets may have different sizes, and may not be completely full. He then pours bucket 1 into bucket 2, then bucket 2 into bucket 3, then bucket 3 into bucket 1, then bucket 1 into bucket 2, and so on in a cyclic fashion, for a total of 100 pour operations (so the 100th pour would be from bucket 1 into bucket 2). When Farmer John pours from bucket a into bucket b, he pours as much milk as possible until either bucket a becomes empty or bucket b becomes full.

    Please tell Farmer John how much milk will be in each bucket after he finishes all 100 pours.
     
    Input
    The first line of the input file contains two space-separated integers: the capacity c1 of the first bucket, and the amount of milk m1 in the first bucket. Both c1 and m1 are positive and at most 1 billion, with c1 ≤ m1. The second and third lines are similar, containing capacities and milk amounts for the second and third buckets.
     
    Output
    Please print three lines of output,giving the final amount of milk in each bucket, after 100 pouroperations.
     
    Example
    Input
    10 3
    11 4
    12 5
    Output
    0
    10
    2
     
    Note
    In this example, the milk in each bucket is as follows during the sequence of pours:
    Initial State: 3 4 5
    1. Pour 1->2: 0 7 5
    2. Pour 2->3: 0 0 12
    3. Pour 3->1: 10 0 2
    4. Pour 1->2: 0 10 2
    5. Pour 2->3: 0 0 12
    (The last three states then repeat in a cycle ...)
     

    题目描述:

    有三个桶,每个桶都有不同量的牛奶。第一次:把第1个桶的牛奶倒进第2个桶,直到第2个桶倒满或者第1个桶的牛奶倒完。第二次:把第2个桶的牛奶倒进第3个桶,直到第3个桶倒满或者第2个桶的牛奶倒完。第三次:把第3个桶的牛奶倒进第1个桶,直到第1个桶倒满或者第3个桶的牛奶倒完。第四次:重复第一次的操作。第五次:重复第二次的操作......,进行了100次倒牛奶的操作,问:现在三个桶里面有多少牛奶?
     

    题目分析:

    这道题直接模拟:我们分析一下”倒“牛奶的操作:
    把左边桶的牛奶倒进右边的桶,有两种情况:
    1.左边的牛奶全部倒进右边:
    2.左边的牛奶还有剩余:
     
    对于第一种情况,先把左边牛奶的量加到右边,然后才把左边的牛奶的量清空(直接设为0)。这里容易错的地方就是有的人会把这两个的先后顺序搞反,导致自己看起来好像明明逻辑对了,但结果就是不对。原因:如果先把左边牛奶的量清空,我们就不知道要从左边倒多少牛奶到右边,错误代码导致的示意图:
    对于第二种情况,先把左边剩下多少牛奶计算出来,然后把右边的牛奶加满(直接设为容量)。这里容易错的地方道理和刚刚差不多:
     
    最后,我们把这个过程弄一个函数,然后按照题目意思直接调用这个倒牛奶的函数就行了。(虽然是道水题,但也不能忽视一些小错误o(≧口≦)o,写题解时发现自己当时的ac代码(无函数版)真丑┭┮﹏┭┮)
     
     
    AC代码:
     1 #include <cstdio>
     2 #include <cstring>
     3 #include <iostream>
     4 using namespace std;
     5 int capa[5], leave[5];
     6 
     7 void pour(int a, int b){
     8     if(leave[a]+leave[b] <= capa[b]){  //第一种情况
     9         leave[b] += leave[a];
    10         leave[a] = 0;
    11     }
    12     else{   //第二种情况
    13         leave[a] -= capa[b]-leave[b];
    14         leave[b] = capa[b];
    15     }
    16 }
    17 
    18 int main(){
    19     for(int i = 1; i <= 3; i++){
    20         cin >> capa[i] >> leave[i];
    21     }
    22 
    23     for(int i = 0; i < 33; i++){
    24         pour(1, 2);   //桶1倒进桶2
    25         pour(2, 3);   //桶2倒进桶3
    26         pour(3, 1);   //桶3倒进桶1
    27     }
    28 
    29     pour(1, 2);   //最后别忘这个
    30 
    31     for(int i = 1; i <= 3; i++){
    32         cout << leave[i] << endl;
    33     }
    34     return 0;
    35 }
     
     
  • 相关阅读:
    十大排序
    算法11----判断是否为回文词(双端队列判断)
    算法10-----分糖果
    算法9-----输出全排列(递归)---移除K个数,剩下最小数。
    算法8-----罗马字转整数(分治法)
    Python数据结构2-----队列和堆
    Python数据结构1-----基本数据结构和collections系列
    Python笔记22-----高阶函数
    10、TV UI
    9、创建向后兼容的用
  • 原文地址:https://www.cnblogs.com/happy-MEdge/p/10530730.html
Copyright © 2020-2023  润新知