eolymp
bolt
Попробуйте наш новый интерфейс для отправки задач
Задачи

Three-way Branch

Three-way Branch

Лимит времени 7 секунд
Лимит использования памяти 64 MiB

There is a grid that consists of W×H cells. The upper-left-most cell is (1, 1). You are standing on the cell of (1, 1) and you are going to move to cell of (W, H). You can only move to adjacent lower-left, lower or lower-right cells.

There are obstructions on several cells. You can not move to it. You cannot move out the grid, either. Write a program that outputs the number of ways to reach (W, H) modulo 1000000009. You can assume that there is no obstruction at (1, 1).

Входные данные

The first line contains three integers, the width W, the height H, and the number of obstructions N. (1W75, 2H10^18, 0N30) Each of following N lines contains 2 integers, denoting the position of an obstruction (x_i, y_i).

The last test case is followed by a line containing three zeros.

Выходные данные

For each test case, print its case number and the number of ways to reach (W, H) modulo 1000000009.

Пример

Входные данные #1
2 4 1
2 1
2 2 1
2 2
0 0 0
Выходные данные #1
Case 1: 4
Case 2: 0
Источник ACM-ICPC Japan Alumni Group Spring Contest 2012 , Tokyo, Japan, 2012-04-15