形如 \(f[i][j]=min(f[i][j],f[i][k]+f[k+1][j]+w[i][j]),k\in[i,j-1]\) 的转移方程

如果满足 \(w[i][j]+w[i+1][j+1]\le w[i][j+1]+w[i+1][j]\)

并且 \(f[i][j]+f[i+1][j+1]\le f[i][j+1]+f[i+1][j]\)

\(w\) 函数和 \(f\) 函数同时满足四边形不等式,也就是交叉小于包含

\(s[i][j]\)\(f[i][j]\) 的最优决策点,则有 \(s[i][j-1]\le s[i][j]\le s[i+1][j]\)

枚举决策点的范围就可以大大减少

可以把 \(dp\) 的时间复杂度从 \(n^3\) 优化为 \(n^2\)

一般来说,如果有一个 \(n^3\)\(dp\)做法满足上面的形式并且该题 \(n^2\) 可过,都可以考虑用四边形不等式去优化

如果不会证明可以打表或者对拍

有两种形式的 \(dp\) 经常用到此类优化

一种是类似于石子合并的区间 \(dp\)

\(f[l][r]\) 为区间 \([l,r]\) 中的最小值

比如 P1880 [NOI1995] 石子合并

另一种是分组 \(dp\)

\(f[i][j]\) 为前 \(i\) 物品分为 \(j\) 组的最小价值

比如 CF321E P4767 [IOI2000]邮局

  1. #include<cstdio>
  2. #include<algorithm>
  3. #include<cstring>
  4. #include<cmath>
  5. #include<iostream>
  6. #define rg register
  7. inline int read(){
  8. rg int x=0,fh=1;
  9. rg char ch=getchar();
  10. while(ch<'0' || ch>'9'){
  11. if(ch=='-') fh=-1;
  12. ch=getchar();
  13. }
  14. while(ch>='0' && ch<='9'){
  15. x=(x<<1)+(x<<3)+(ch^48);
  16. ch=getchar();
  17. }
  18. return x*fh;
  19. }
  20. const int maxn=4e3+5;
  21. int n,m,a[maxn][maxn],sum[maxn][maxn],f[maxn][maxn],w[maxn][maxn],g[maxn][maxn];
  22. int main(){
  23. memset(f,0x3f,sizeof(f));
  24. n=read(),m=read();
  25. for(rg int i=1;i<=n;i++){
  26. for(rg int j=1;j<=n;j++){
  27. a[i][j]=read();
  28. }
  29. }
  30. for(rg int i=1;i<=n;i++){
  31. for(rg int j=1;j<=n;j++){
  32. sum[i][j]=sum[i-1][j]+sum[i][j-1]-sum[i-1][j-1]+a[i][j];
  33. }
  34. }
  35. for(rg int i=1;i<=n;i++){
  36. for(rg int j=1;j<i;j++){
  37. w[j][i]=(sum[i][i]-sum[i][j-1]-sum[j-1][i]+sum[j-1][j-1])>>1;
  38. }
  39. }
  40. f[0][0]=0;
  41. for(rg int i=0;i<=m;i++) g[n+1][i]=n;
  42. for(rg int j=1;j<=m;j++){
  43. for(rg int i=n;i>=1;i--){
  44. for(rg int k=g[i][j-1];k<=g[i+1][j];k++){
  45. if(f[i][j]>f[k][j-1]+w[k+1][i]){
  46. f[i][j]=f[k][j-1]+w[k+1][i];
  47. g[i][j]=k;
  48. }
  49. }
  50. }
  51. }
  52. printf("%d\n",f[n][m]);
  53. return 0;
  54. }

版权声明:本文为liuchanglc原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/liuchanglc/p/14332356.html