ACMSGURU 551 - Preparing Problem

2021-08-11 10:55:33 浏览数 (1)

Preparing Problem

Problem Description

It is not easy to prepare a problem for a programming contest. Petya and Vasya decided that problem “A B” needs at least n distinct solutions to be written. It doesn’t matter how many solutions each of them will write, they need to write at least n solutions in total. We know that Petya needs t1 units of time to write a solution, and Vasya needs t2 units of time. They start to work simultaneously at time 0. Thus, for example, Petya finishes writing his first solution at time t1, his second solution at 2 · t1 and so on.

Petya and Vasya are working by the same algorithm. Each time Petya (Vasya) finishes writing a solution, he checks on how many solutions have already been written up to the current time moment t. Ready solutions are the solutions that have been fully written by this time. The solutions that were fully finished exactly at time t are also considered ready. If the number of such solutions is strictly less than n, then Petya (Vasya) starts writing the next solution. If a member of the jury began working on a problem, he doesn’t stop working under any circumstances, and he will surely finish it.

Petya and Vasya realize that if they act on this algorithm, they will not necessarily write exactly n solutions in total. Maybe they’ll write more solutions.

Considering that Petya and Vasya work non-stop, find, how many solutions they wrote in total and the moment when the latest solution was finished. The latest solution is one which was finished last.

Input

The only input line contains three integers n, t1 and t2 (1 ≤ n, t1, t2 ≤ 5000).

Output

Print two integers — m and f, where m is the number of written solutions, and f is the moment when the last solution was finished.

Example(s)

sample input

sample output

5 2 3

5 6

sample input

sample output

5 2 4

6 8

sample input

sample output

3 30 50

4 100

Note

In the first sample Petya finished his solutions at time 2, 4 and 6, and Vasya — at time 3 and 6. They finished writing their last solutions simultaneously, at time 6, and at this exact moment they already had the total of 5 written solutions and stopped working.

Solution

代码语言:javascript复制
#include <bits/stdc  .h>

int main() {
#define int long long
    std::ios::sync_with_stdio(false);
    int n, t1, t2;
    std::cin >> n >> t1 >> t2;

    if(t1 > t2) {
        std::swap(t1, t2);
    }

    int left = 1;
    int right = n;
    int CountT1 = 0;
    while(left <= right) {
        int mid = (left   right) / 2;
        int currentCount = mid   (mid * t1) / t2;
        if(currentCount < n) {
            left = mid   1;
        } else {
            right = mid - 1;
            CountT1 = mid;
        }
    }

    int CountT2 = CountT1 * t1 / t2;
    CountT2  = (CountT1   CountT2 <= n && CountT2 * t2 < CountT1 * t1) ? 1 : 0;

    std::cout << CountT1   CountT2  << " " << std::max(t1 * CountT1, t2 * CountT2) << std::endl;
    return 0;
}

0 人点赞