先从简单一点的bzoj2431入手: n个数1~n已经限定了,所以 对于1~i-1,新加入i,最多可以增加i-1个逆序对,最少增加0个逆序对 f[i,j]表示1~i形成的序列逆序对为j的方案数 比较容易得出f[i,j]=Σf[i-1,k]; 用前缀和优化即可 ; ..,..] of longint; s:..] of longint; i,j,k,n,m,p:longint; begin readln(n,m); k:=; f[,]:=; to n do be…
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2431 很容易想到n^3的做法.就是前 i 个数用第 i 个数最多能 i - 1 个逆序对,所以 i - 1 个数中属于 j ~ j - i + 1 的值都能加到前 i 个数的状态上. #include<iostream> #include<cstdio> #include<cstring> ,mod=; int n,k,dp[N][N],sm[N]; int ma…