Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- using System;
- class Tubes
- {
- static void Main()
- {
- int n = int.Parse(Console.ReadLine());
- int m = int.Parse(Console.ReadLine());
- int left = 0;
- int right = 0;
- int mid = 0;
- int[] tube = new int[n];
- for (int i = 0; i < n; i++)
- {
- tube[i] = int.Parse(Console.ReadLine());
- if (right < tube[i])
- {
- right = tube[i];
- }
- }
- mid = (left + right) / 2;
- int maxTube = -1;
- long numOfTubes = 0;
- while (left <= right)
- {
- numOfTubes = 0;
- for (int i = 0; i < n; i++)
- {
- numOfTubes += tube[i] / mid;
- }
- if (numOfTubes >= m)
- {
- left = mid + 1;
- maxTube = mid;
- }
- else
- {
- right = mid - 1;
- }
- mid = (left + right) / 2;
- }
- Console.WriteLine(maxTube);
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement