抱歉,您的浏览器无法访问本站

本页面需要浏览器支持(启用)JavaScript


了解详情 >

问存在多少个长度为 n(2n5000)n\,(2\le n\le 5000) 的单调不减序列 aa,满足 1ain1\le a_i\le n,且对于任意 k(1k<n)k\,(1\le k<n),都有:对任意大小为 kk 的子集 SS 和大小为 k+1k+1 的子集 TT,满足 xSAx<xTAx\sum_{x\in S}A_x<\sum_{x\in T}A_x。答案对大质数 mm 取模。

首先需要发现一个性质,就是如果 k=n2k=\left\lfloor\frac{n}{2}\right\rfloor 的时候满足了,那么其他的 kk 都能满足。为什么呢?首先是对于每个 kk,显然如果满足了 i=1k+1aii=nk+1nai\sum_{i=1}^{k+1}a_i\ge \sum_{i=n-k+1}^na_i,就满足所有的 SSTT 了。然后如果满足了 k=n2k=\left\lfloor\frac{n}{2}\right\rfloor 的情况,如果 k>n2k>\left\lfloor\frac{n}{2}\right\rfloor,考虑到序列单调不降,左边加上一个较大的数,右边加上一个较小的数,那么不等式肯定仍然成立。否则,如果 k<n2k<\left\lfloor\frac{n}{2}\right\rfloor,其实就是左边减去一个较小的数,右边加上一个较大的数,不等式也仍然成立。

那这个东西有什么用呢,我们考虑对一波式子。首先我们需要去掉一个单调性,我们构造一个差分数组 Δai=aiai1\Delta a_i=a_i-a_{i-1},为了不让 Δa1\Delta a_1 奇怪,我们就让 a0=1a_0=1,这样子其实就是 ai=1+i=1nΔaia_i=1+\sum_{i=1}^n\Delta a_i,然后我们的式子就变成了:

i=1n2+1j=1iΔaji=nn2+1nj=1iΔaj\sum_{i=1}^{\left\lfloor\frac{n}{2}\right\rfloor+1}\sum_{j=1}^i\Delta a_j\ge \sum_{i=n-\left\lfloor\frac{n}{2}\right\rfloor+1}^n\sum_{j=1}^i\Delta a_j

这个下取整感觉很难受,我们就直接将 nn 奇偶讨论好了:

nn 是奇数时,n2=n12\left\lfloor\frac{n}{2}\right\rfloor=\frac{n-1}{2},也就是原式就变成了:

i=1n+12j=1iΔaji=n+12+1nj=1iΔaj\sum_{i=1}^{\frac{n+1}{2}}\sum_{j=1}^i\Delta a_j\ge \sum_{i=\frac{n+1}{2}+1}^n\sum_{j=1}^i\Delta a_j

两边都加个 i=1n+12j=1iΔaj\sum_{i=1}^{\frac{n+1}{2}}\sum_{j=1}^i\Delta a_j 把右边给补一下:

2i=1n+12j=1iΔaji=1nj=1iΔaj2\sum_{i=1}^{\frac{n+1}{2}}\sum_{j=1}^i\Delta a_j\ge \sum_{i=1}^n\sum_{j=1}^i\Delta a_j

根据套路,我们需要把前面的 Σ\Sigma 拆掉,于是我们拆掉它:

2i=1n+12(n+12i+1)Δaii=1n(ni+1)Δai2\sum_{i=1}^{\frac{n+1}{2}}\left(\frac{n+1}{2}-i+1\right)\Delta a_i\ge \sum_{i=1}^n\left(n-i+1\right)\Delta a_i

考虑我们将 aia_i 差分的目的,其实就是想把左边的式子减过去,然后合并起来:

i=1nciΔai0\sum_{i=1}^nc_i\Delta a_i\le 0

其中

ci={i2in+12ni+1i>n+12c_i= \begin{cases} i-2 & i\le \frac{n+1}{2}\\ n-i+1 & i>\frac{n+1}{2} \end{cases}

同样地,我们来考虑 nn 是偶数的情况:

i=1n2j=1iΔaji=n2+2nj=1iΔaj\sum_{i=1}^{\frac{n}{2}}\sum_{j=1}^i\Delta a_j\ge \sum_{i=\frac{n}{2}+2}^n\sum_{j=1}^i\Delta a_j

补一补:

2i=1n2j=1iΔaji=1nj=1iΔaji=1n2+1Δai2\sum_{i=1}^{\frac{n}{2}}\sum_{j=1}^i\Delta a_j\ge \sum_{i=1}^n\sum_{j=1}^i\Delta a_j-\sum_{i=1}^{\frac{n}{2}+1}\Delta a_i

拆个 Σ\Sigma

2i=1n2(n2i+1)Δaii=1n(ni+1)Δaii=1n2+1Δai2\sum_{i=1}^{\frac{n}{2}}\left(\frac{n}{2}-i+1\right)\Delta a_i\ge \sum_{i=1}^n\left(n-i+1\right)\Delta a_i-\sum_{i=1}^{\frac{n}{2}+1}\Delta a_i

写成 ciΔai0\sum c_i\Delta a_i\le 0 的形式,可以得到:

ci={i2in2nii=n2+1ni+1i>n2+1c_i= \begin{cases} i-2 & i\le\frac{n}{2}\\ n-i & i=\frac{n}{2}+1\\ n-i+1 & i>\frac{n}{2}+1 \end{cases}

不难发现当 i=n2+1i=\frac{n}{2}+1 时,ni=n21=i2n-i=\frac{n}{2}-1=i-2,所以:

ci={i2in2+1ni+1i>n2+1c_i= \begin{cases} i-2 & i\le\frac{n}{2}+1\\ n-i+1 & i>\frac{n}{2}+1 \end{cases}

综合奇偶两个式子,我们均可以得到:

i=1nciΔai0\sum_{i=1}^nc_i\Delta a_i\le 0

其中

ci={i2in2+1ni+1i>n2+1c_i= \begin{cases} i-2 & i\le\left\lfloor\frac{n}{2}\right\rfloor+1\\ n-i+1 & i>\left\lfloor\frac{n}{2}\right\rfloor+1 \end{cases}

我们回到题目,除了这个条件,我们再回过头来看看有什么缺的条件,仔细找了找好像只有 Δai+1n\sum\Delta a_i+1\le n 了。

于是我们考虑确定 a2ana_2\sim a_n 的值,然后回过头来看看有多少个符合条件的 a1a_1

我们发现只有两个条件:

{a1n1i=2naia1i=2nciai\begin{cases} a_1\le n-1-\sum_{i=2}^na_i\\ a_1\ge \sum_{i=2}^nc_ia_i \end{cases}

于是满足条件的 a1a_1 个数就是:

max(0,ni=2n(ci+1)ai)\max\left(0, n-\sum_{i=2}^n\left(c_i+1\right)a_i\right)

我们令 fif_i 表示 j=2n(cj+1)aj=i\sum_{j=2}^n\left(c_j+1\right)a_j=i 的方案数,那么最终的答案就是 i=0n1(ni)fi\sum_{i=0}^{n-1} (n-i)\cdot f_i

我们最后要做的一件事情就是计算 fif_i 了,不难发现其实就是一个背包,第 ii 个物品重量 cic_i,可以选 aia_i 个,直接大力 dp 过去即可。

于是复杂度 O(n2)\mathcal{O}(n^2)

代码

评论