# 2019 USACO January

# Train Tracking 2

Every day the express train goes past the farm. It has **n** carriages, each with a positive integer label between **1** and `10`

, different carriages may have the same label.^{9}

Usually, Bessie watches the train go by, tracking the carriage labels. But today is too foggy, and Bessie can't see any of the labels! Luckily, she has acquired the sliding window minimums of the sequence of carriage labels, from a reputable source in the city. In particular, she has a positive integer **k**, and **n** − **k** + **1** positive integers `c`

,..., _{1}`c`

+ _{n}**1** − **k**, where `c`

is the minimum label among carriages _{i}**i**, **i** + **1**,..., **i** + **k** − **1**.

Help Bessie figure out the number of ways to assign a label to each carriage, consistent with the sliding window minimums. Since this number may be very large, Bessie will be satisfied if you find its remainder modulo `10`

+ ^{9}**7**.

Bessie's information is completely reliable; that is, it is guaranteed that there is at least one consistent way to assign labels.

#### Input

The first line consists of two space-separated integers **n** (**1** ≤ **n** ≤ `10`

) and ^{5}**k**. The subsequent lines contain the sliding window minimums `c`

, ..., _{1}`c`

+ _{n}**1** − **k**, one per line.

#### Output

Print a single integer: the number of ways, modulo `10`

+ ^{9}**7**, to assign a positive integer not exceeding `10`

to each carriage, such that the minimum label among carriages ^{9}**i**, **i** + **1**, ..., **i** + **k** − **1** is `c`

for each _{i}**1** ≤ **i** ≤ **n** − **k** + **1**.

4 2 999999998 999999999 999999998

3