AtCoder Beginner Contest 221 H. Count Multiset(容斥 dp 拆分数 差分 数形结合)
题目给定m,n(m0的方案数考虑暴力转移,从1到m,枚举最后一段0的连续段长度,也就是枚举上一个非0的位置x,再枚举b[i]选择的数为w,有:对的第一维,也就是g[x]这一维维护前缀和,即可实现转移,复杂度题解3考虑直接对原序列做dp,f[i][j]表示前i个数和为j的方案数如:原序列112,①每次要么新增一个1,转移到1112,f[i][j]从f[i-1][j-1]转移②要么令所有数都+1,使得