write a go solution for Description: There are n boxes placed in a line. The boxes are numbered from 1 to n. Some boxes contain one ball inside of them, the rest are empty. At least one box contains a ball and at least one box is empty. In one move, you have to choose a box with a ball inside and an adjacent empty box and move the ball from one box into another. Boxes i and i+1 for all i from 1 to n-1 are considered adjacent to each other. Boxes 1 and n are not adjacent. How many different arrangements of balls exist after exactly k moves are performed? Two arrangements are considered different if there is at least one such box that it contains a ball in one of them and doesn't contain a ball in the other one. Since the answer might be pretty large, print its remainder modulo 10^9+7. Input Format: The first line contains two integers n and k (2<=n<=1500; 1<=k<=1500) — the number of boxes and the number of moves. The second line contains n integers a_1,a_2,...,a_n (a_iin0,1) — 0 denotes an empty box and 1 denotes a box with a ball inside. There is at least one 0 and at least one 1. Output Format: Print a single integer — the number of different arrangements of balls that can exist after exactly k moves are performed, modulo 10^9+7. Note: In the first example, there are the following possible arrangements: - 0 1 1 0 — obtained after moving the ball from box 1 to box 2; - 1 0 0 1 — obtained after moving the ball from box 3 to box 4; - 1 1 0 0 — obtained after moving the ball from box 3 to box 2. In the second example, there are the following possible arrangements: - 1 0 1 0 — three ways to obtain that: just reverse the operation performed during the first move; - 0 1 0 1 — obtained from either of the first two arrangements after the first move.. Output only the code with no comments, explanation, or additional text.