Задача B. Ферзи на шахматной доске

Автор:А. Жуплев   Ограничение времени:1 сек
Входной файл:input.txt   Ограничение памяти:64 Мб
Выходной файл:output.txt  
Максимальный балл:50  

Условие

Ферзь — шахматная фигура, которая может двигаться на любое число клеток по горизонтали, вертикали или диагонали.

На бесконечной шахматной доске расположены K ферзей. Требуется вывести прямоугольный фрагмент шахматной доски, заданный двумя противоположными клетками с координатами (XA; YA) и (XB; YB).

Клетки чёрного цвета обозначаются символом '#' (ASCII 35), клетки белого цвета обозначаются символом '.' (точка, ASCII 46), клетка с ферзем обозначается символом 'X' (ASCII 88), клетка, в которую может походить ферзь обозначается символом '*' (ASCII 42).

Ось ординат (OY) направлена вертикально вниз. Клетка с координатами (1; 1) имеет чёрный цвет.

Формат входного файла

Во входном файле содержатся числа XA YA XB YB K

Далее следуют K пар чисел — Xi Yi

Формат выходного файла

Выходной файл должен содержать изображение заданного фрагмента шахматной доски.

Ограничения

1 ≤ Xi, Yi ≤ 231 − 1

0 ≤ K ≤ 105

1 ≤ |XA − XB|, |YA − YB| ≤ 500

В одной клетке не может находиться более одного ферзя

Примеры тестов

Входной файл (input.txt) Выходной файл (output.txt)
1
1 8 8 1
2
7 1
3 5
******X*
.#*#.***
*.*.*.*.
.***.#*#
**X*****
.***.#*#
*.*.*.*.
.#*#.**#
2
6987879 87979870 6987899 87979879
1
3271487 84263477
.*.#.#.#.#.#.#.#.#.#.
#.*.#.#.#.#.#.#.#.#.#
.#.*.#.#.#.#.#.#.#.#.
#.#.*.#.#.#.#.#.#.#.#
.#.#.*.#.#.#.#.#.#.#.
#.#.#.*.#.#.#.#.#.#.#
.#.#.#.*.#.#.#.#.#.#.
#.#.#.#.*.#.#.#.#.#.#
.#.#.#.#.*.#.#.#.#.#.
#.#.#.#.#.*.#.#.#.#.#

0.057s 0.009s 13