atcoder#ARC086D. [ARC086F] Shift and Decrement

[ARC086F] Shift and Decrement

Score : 12001200 points

Problem Statement

There are NN non-negative integers written on the blackboard: A1,...,ANA_1, ..., A_N.

Snuke can perform the following two operations at most KK times in total in any order:

  • Operation A: Replace each integer XX on the blackboard with XX divided by 22, rounded down to the nearest integer.
  • Operation B: Replace each integer XX on the blackboard with XX minus 11. This operation cannot be performed if one or more 00s are written on the blackboard.

Find the number of the different possible combinations of integers written on the blackboard after Snuke performs the operations, modulo 1,000,000,0071,000,000,007.

Constraints

  • 1N2001 \leq N \leq 200
  • 1Ai10181 \leq A_i \leq 10^{18}
  • 1K10181 \leq K \leq 10^{18}
  • AiA_i and KK are integers.

Input

Input is given from Standard Input in the following format:

NN KK

A1A_1 A2A_2 ...... ANA_N

Output

Print the number of the different possible combinations of integers written on the blackboard after Snuke performs the operations, modulo 1,000,000,0071,000,000,007.

2 2
5 7
6

There are six possible combinations of integers on the blackboard: (1,1)(1, 1), (1,2)(1, 2), (2,3)(2, 3), (3,5)(3, 5), (4,6)(4, 6) and (5,7)(5, 7). For example, (1,2)(1, 2) can be obtained by performing Operation A and Operation B in this order.

3 4
10 13 22
20
1 100
10
11
10 123456789012345678
228344079825412349 478465001534875275 398048921164061989 329102208281783917 779698519704384319 617456682030809556 561259383338846380 254083246422083141 458181156833851984 502254767369499613
164286011