c/c++语言开发共享题解 P4850 【[IOI2009]葡萄干raisins】

题目地址:https://www.luogu.com.cn/problem/P4850题解原地址:https://createsj.blog.luogu.org/solution-p4850 …

题目地址:https://www.luogu.com.cn/problem/p4850

题解原地址:


既然大家都在用记忆化搜索,那我就来个 dp 题解吧。有了 o2 谁还会用 dp ?!

状态转移方程很容易推出来。设问题给出的矩阵为 (textbf a),其有一子矩阵,左上角坐标为 ((x_1,y_1)) ,右下角坐标为 ((x_2,y_2)) ,那么当只考虑这个子矩阵时,最优解为将该子矩阵切开后的两个矩阵的最优解的最小值与该子矩阵的各元素之和,即

[ f_{x_1,y_1,x_2,y_2}=min_{x_1,y_1,x_2,y_2}+sumlimits_{i=x_1}{x_2}sumlimits_{j=y_1}^{y_2}textbf a(i,j). ]

这个很容易用记忆化搜索实现,但应如何 dp 呢?

容易想到,我们应该枚举每个行数和列数不都为 (1) 的子矩阵,并保证该子矩阵的任意子矩阵都已得出最优解。为了方便实现,我们设一子矩阵左上角坐标为 ((i,j)) ,有 (k)(l) 列,那么当只考虑这个子矩阵时,最优解为

[ f_{i,j,k,l}=min_{i,j,k,l}+sumlimits_{x=1}^ksumlimits_{y=1}^ltextbf a(x+i,y+j). ]

这个状态转移方程与上面的等价,但能方便我们用 dp 实现。

至于求子矩阵各元素之和,我们可以利用前缀和的思想,用 (sum_{i,j}) 表示左上角坐标为 ((1,1)) ,右下角坐标为 ((i,j)) 的子矩阵各元素之和,那么左上角坐标为 ((i,j))(k)(l) 列的子矩阵各元素之和为

[ sumlimits_{x=1}^ksumlimits_{y=1}^ltextbf a(x+i,y+j)=sum_{i+k-1,j+l-1}-sum_{i+k-1,j-1}-sum_{i-1,j+l-1}+sum_{i-1,j-1}. ]

为了消去 (-1),我们设一子矩阵左上角坐标为 ((i+1,j+1)) ,有 (k)(l) 列,那么当只考虑这个子矩阵时,最优解为 (f_{i,j,k,l})

核心代码如下:

// i,j,k,l 的意义已经说明 for(register int i,j,k=1,l,c,xs,ys,min,t;k<=n;++k)     for(l=1;l<=m;++l)         if(k!=1 || l!=1)             for(i=0,xs=n-k;i<=xs;++i)// xs 是为了限制 i,减少运算次数                 for(j=0,ys=m-l;j<=ys;++j)//ys 同理                 {                     // min 表示将该子矩阵切开后的两个矩阵的最优解的最小值                     min=0x7fffffff;                     // 横着切                     for(c=1;c<k;++c)                     {                         t=f[i][j][c][l]+f[i+c][j][k-c][l];                         if(t<min)                             min=t;                     }                     // 竖着切                     for(c=1;c<l;++c)                     {                         t=f[i][j][k][c]+f[i][j+c][k][l-c];                         if(t<min)                             min=t;                     }                     // 状态转移方程                     f[i][j][k][l]=min+sum[i+k][j+l]-sum[i+k][j]-sum[i][j+l]+sum[i][j];                 }

不用开 o2 就可以过,证明一切。

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/c-cdevelopment/600249.html

(0)
上一篇 2021年5月9日
下一篇 2021年5月9日

精彩推荐