#P3223. 摆花(数据加强版)

摆花(数据加强版)

本题是原题的数据加强版,修改了数据范围\red{数据范围}模数\red{模数}

题目描述

小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m\red{m}盆。通过调查顾客的喜好,小明列出了顾客最喜欢的n\red{n}种花,从1\red{1}n\red{n}标号。

为了在门口展出更多种花,规定第i种花不能超过 ai\red{a_i} 盆,摆花时同一种花放在一起,且不同种类的花需按标号的从小到大的顺序依次摆列。

试编程计算,一共有多少种不同的摆花方案。

输入格式

输入文件共2\red{2}行。第一行包含两个正整数n\red{n}m\red{m},中间用一个空格隔开。第二行有n\red{n}个整数,每两个整数之间用一个空格隔开,依次表示a1a2an\red{a_1、a_2、……a_n}

输出格式

输出只有一行,一个整数,表示有多少种方案。注意:因为方案数可能很多,请输出方案数对1e9+9取模的结果。

样例

样例输入

2 4
3 2

样例输出

2

数据范围与提示

【输入输出样例说明】

2\red{2} 种摆花的方案,分别是(1112)(1122)\red{(1,1,1,2), (1,1,2,2)}。括号里的 1\red{1}2\red{2} 表示两种花,比如第一个方案是前三个位置摆第一种花,第四个位置摆第二种花。

数据范围

对于100%数据,有0<n10000<m10000ai1000对于 \red{100\%}数据,有 \red{0 < n \leq 1000,0 < m \leq 1000,0 \leq a_i \leq 1000。}