Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- using System;
- class Program
- {
- static int n, w, h;
- static int[] x = new int[110], y = new int[110];
- static int ansx, ansy;
- static bool GO(int l)
- {
- for (int k = 0; k < n; k++)
- {
- int left = x[k];
- for (int up = 0; up <= h; up++)
- {
- bool can = true;
- int right = left + l, down = up + l;
- if (right > w || down > h)
- can = false;
- for (int i = 0; i < n && can; i++)
- if (x[i] > left && x[i] < right &&
- y[i] > up && y[i] < down)
- can = false;
- if (can)
- {
- ansx = left; ansy = up;
- return true;
- }
- }
- }
- for (int k = 0; k < n; k++)
- {
- int up = y[k];
- for (int left = 0; left <= w; left++)
- {
- int right = left + l, down = up + l;
- bool can = true;
- if (right > w || down > h)
- can = false;
- for (int i = 0; i < n && can; i++)
- if (x[i] > left && x[i] < right &&
- y[i] > up && y[i] < down)
- can = false;
- if (can)
- {
- ansx = left; ansy = up;
- return true;
- }
- }
- }
- return false;
- }
- static void Main()
- {
- string[] Buff = Console.ReadLine().Split();
- n = int.Parse(Buff[0]);
- w = int.Parse(Buff[1]);
- h = int.Parse(Buff[2]);
- for (int i = 1; i <= n; i++)
- {
- Buff = Console.ReadLine().Split();
- x[i] = int.Parse(Buff[0]);
- y[i] = int.Parse(Buff[1]);
- }
- x[n + 1] = w; y[n + 1] = h; n += 2;
- int l = 0, r = Math.Min(w, h), m;
- while (l <= r)
- {
- m = (l + r) / 2;
- if (GO(m))
- l = m + 1;
- else r = m - 1;
- }
- Console.WriteLine(ansx + " " + ansy + " " + (l - 1));
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement