Thay đổi màu

Xem PDF

Điểm: 2100 (p) Thời gian: 1.0s Bộ nhớ: 1G Input: bàn phím Output: màn hình

Lê xếp \(n\) hạt cườm thành một vòng tròn theo chiều kim đồng hồ, ban đầu, các hạt có mã màu lần lượt tương ứng là \(a_1 = 0, a_2 = 0,..., a_n = 0\). Lê có hai loại lệnh để thay đổi mã màu như sau:

  • Lệnh D i, gấp đôi mã màu của một hạt, cụ thể: \(a_i = a_i \times 2\), lệnh này chỉ được thực hiện nếu \(a_i > 0\).
  • Lệnh P i, gấp đôi và thêm \(1\) và mã màu của hai hạt kề nhau, cụ thể: \(a_i = a_i \times 2 + 1\)\(a_j = a_j \times 2 + 1\), trong đó \(j\) là hạt kề tiếp theo của hạt \(i\) theo chiều kim đồng hồ.

Lê muốn tìm cách thay đổi dãy mã màu ban đầu (tất cả đều bằng \(0\)) về trạng thái yêu thích bằng cách dùng hai loại lệnh trên.

Yêu cầu: Cho dãy số nguyên không âm \(b_1,b_2,...,b_n\), hãy giúp Lê đếm số cách thay đổi dãy mã màu ban đầu về dãy mã màu \(b_1,b_2,...,b_n\) (hai cách được gọi là khác nhau nếu số bước sử dụng khác nhau hoặc ở bước thứ \(t\) của cách này sử dụng lệnh khác với lệnh thứ \(t\) của cách kia).

Input

  • Dòng đầu tiên gồm số nguyên \(n\).
  • Dòng thứ hai chứa \(n\) số nguyên không âm \(b_1,b_2,...,b_n\).

Output

  • Một dòng chứa một số là phần dư khi chia số cách thực hiện được cho \(10^9+7\).

Scoring

  • Subtask \(1\) (\(25\%\) số điểm): \(n = 3, b_i \le 3\).
  • Subtask \(2\) (\(25\%\) số điểm): \(n = 3, b_i \le 30\).
  • Subtask \(3\) (\(25\%\) số điểm): \(n \le 5, b_i \le 1000\).
  • Subtask \(4\) (\(25\%\) số điểm): \(n \le 5, b_i \le 10000\).

Example

Test 1
Input
3
1 3 2
Output
3

Bình luận

Không có bình luận nào.