题意:按要求完成n个任务,每个任务必须进行a[i]次才算完成,且按要求,第i个任务必须在大于i任务完成之前完成,问有多少种完成顺序的组合.(n<=1000 a[i] <= 1e6 mod = 1e9+7) 思路:组合问题,从任务序号低的开始完成,由于必须使序号高的在后,所以必定在末尾的数字是高序号的,那么对剩余的a[i]-1个数字进行插空法,一个序号有C(cnt+a[i]-1,a[i]-1)种,剩下的就是Lucas定理了(数据小不用也能过),但是要注意预处理出逆元,不然会TLE. /** @D…