[MM68-易] Fill the Bowl
Problem Description
You have two empty bowls with volume a and b units (a and b are positive integers). You want to design a bottle, so that you can fill each bowl with water `perfectly’ as follows:
(i) Fill the bottle fully with water.
(ii) Empty the bottle completely by pouring the water to the bowl, and no water should get out of the bowl.
(iii) Repeat (i) and (ii) if the bowl is not full.
You hope to design a bottle with as large volume as possible, so that you can fill a bowl in fewer rounds. However, no water should be wasted in the above filling process (that is, when emptying the bottle in (ii), no water should get out of the bowl), and due to some limitation, the volume of the bottle is at most Lunits. How large a bottle can you design?
Input File Format
Each test case consists of a line containing three positive integers, a, b, and L, with a, b, L <= 1000.
Output Format
For each test case, output in a line the maximum volume of the bottle.
Example
You have two empty bowls with volume a and b units (a and b are positive integers). You want to design a bottle, so that you can fill each bowl with water `perfectly’ as follows:
(i) Fill the bottle fully with water.
(ii) Empty the bottle completely by pouring the water to the bowl, and no water should get out of the bowl.
(iii) Repeat (i) and (ii) if the bowl is not full.
You hope to design a bottle with as large volume as possible, so that you can fill a bowl in fewer rounds. However, no water should be wasted in the above filling process (that is, when emptying the bottle in (ii), no water should get out of the bowl), and due to some limitation, the volume of the bottle is at most Lunits. How large a bottle can you design?
Input File Format
Each test case consists of a line containing three positive integers, a, b, and L, with a, b, L <= 1000.
Output Format
For each test case, output in a line the maximum volume of the bottle.
Example
Sample Input: | Sample Output: |
6 8 3 4 11 10 9 36 5 | 2 1 3 |
- #include <iostream>
- #include <algorithm>
- #include <string>
- #include <sstream>
- #include <stdio.h>
- #include <ctype.h>
- #include <cmath>
- using namespace std;
- int main() {
- // [MM68-易] Fill the Bowl
- int a, b, L;
- while(cin >> a >> b >> L)
- {
- if(a < b)
- {
- for(int i = a;i > 0;i--)
- {
- if(b % i == 0 && a % i == 0 && i <= L)
- {
- cout << i << endl;
- break;
- }
- }
- }
- else //a > b
- {
- for(int i = b;i > 0;i--)
- {
- if(b % i == 0 && a % i == 0 && i <= L)
- {
- cout << i << endl;
- break;
- }
- }
- }
- }
- return 0;
- }
沒有留言:
張貼留言