[luogu1373]小a和uim之大逃离_动态规划
小a和uim之大逃离
题目大意:有一个n*m的矩阵。每个格子上有一坨0~k不等量的权值。有两个人,每个人任选一个格子作为出发点,并只能向下或向右走。求最后两个人所得到的权值mod k相等的方案数。
注释:$1\le n,m\le 800$,$1\le k \le 15$。
想法:dp。
状态:dp[i][j][k][0/1]表示在点 (i,j),差值为h,小A还是uim取液体的方案数(0-->小A 1-->uim)
转移:
dp[i][j][h][1]+=(dp[i-1][j][(h-a[i][j]+k)%k][0])
uim取,差值就变小了
dp[i][j][h][1]+=(dp[i][j-1][(h-a[i][j]+k)%k][0]
dp[i][j][h][0]+=(dp[i-1][j][(h+a[i][j])%k][1])
小A取
dp[i][j][h][0]+=(dp[i][j-1][(h+a[i][j])%k][1])
初始化:dp[i][j][a[i][j]][0]=1;
一开始小A可以从任意点开始
最后,附上丑陋的代码... ...
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define mod 1000000007
#define N 805
#define K 20
using namespace std;
typedef long long ll;
int a[N][N];
int dp[N][N][K][2];
int n,m,k;
// void right()
// {
// for(int i=1;i<=n;i++)
// {
// for(int j=1;j<=m;j++)
// {
// cout << i << " , " << j << " : " ;
// for(int h=0;h<k;h++)
// {
// cout << dp[i][j][h][1] << " " ;
// }
// cout << endl ;
// }
// }
// }
int main()
{cin >> n >> m >> k ; k ++ ;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){scanf("%d",&a[i][j]);}}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){dp[i][j][a[i][j]%k][0]=1;}}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){for(int h=0;h<=k;h++){dp[i][j][h][0]=(dp[i][j][h][0]+dp[i-1][j][(h-a[i][j]+k)%k][1])%mod;dp[i][j][h][0]=(dp[i][j][h][0]+dp[i][j-1][(h-a[i][j]+k)%k][1])%mod;dp[i][j][h][1]=(dp[i][j][h][1]+dp[i-1][j][(h+a[i][j])%k][0])%mod;dp[i][j][h][1]=(dp[i][j][h][1]+dp[i][j-1][(h+a[i][j])%k][0])%mod;}}}ll ans=0;// right();for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){ans=(ans+dp[i][j][0][1])%mod;}}printf("%lld\n",ans);return 0;
}
小结:注意dp时的最后一维是0还是1,考虑转移的时候容易gg
转载于:https://www.cnblogs.com/ShuraK/p/9023011.html
[luogu1373]小a和uim之大逃离_动态规划相关推荐
- 洛古 P1373 小a和uim之大逃离
P1373 小a和uim之大逃离 题目提供者lzn 标签 动态规划 洛谷原创 难度 提高+/省选- 题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电 ...
- 洛谷P1373 小a和uim之大逃离
P1373 小a和uim之大逃离 题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电,一阵阵雷声.刹那间,狂风大作,乌云布满了天空,紧接着豆大的雨点从 ...
- 小a和uim之大逃离,洛谷之提高历练地,动态规划TG.lv(1)(3-2)
正题 第二题:小a和uim之大逃离 这题有点烦,但是我们可以从k入手,大小为k的魔瓶,可以装的容量为0到k,那么相当于我们每一次mod 一下k 就行了. 我们当然也可以从小a和小uim的魔瓶差入手,我 ...
- 洛谷1373 小a和uim之大逃离
https://www.luogu.org/problem/show?pid=1373 题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电,一阵阵雷声 ...
- luogu P1373 小a和uim之大逃离
题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电,一阵阵雷声.刹那间,狂风大作,乌云布满了天空,紧接着豆大的雨点从天空中打落下来,只见前方出现了一个 ...
- 洛谷1373小a和uim之大逃离
题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电,一阵阵雷声.刹那间,狂风大作,乌云布满了天空,紧接着豆大的雨点从天空中打落下来,只见前方出现了一个 ...
- [P1373]小a和uim之大逃离
题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电,一阵阵雷声.刹那间,狂风大作,乌云布满了天空,紧接着豆大的雨点从天空中打落下来,只见前方出现了一个 ...
- 【题解】洛谷P1373 小a和uim之大逃离(dp 递推)
题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电,一阵阵雷声.刹那间,狂风大作,乌云布满了天空,紧接着豆大的雨点从天空中打落下来,只见前方出现了一个 ...
- 【洛谷P3818】小A和uim之大逃离 II
题目背景 话说上回--还是参见 https://www.luogu.org/problem/show?pid=1373 吧 小a和uim再次来到雨林中探险.突然一阵南风吹来,一片乌云从南部天边急涌过来 ...
- LUOGU P1373 小a和uim之大逃离 题解
题目背景 小a和uim来到雨林中探险.突然一阵北风吹来,一片乌云从北部天边急涌过来,还伴着一道道闪电,一阵阵雷声.刹那间,狂风大作,乌云布满了天空,紧接着豆大的雨点从天空中打落下来,只见前方出现了一个 ...
最新文章
- 获取当前元素在兄弟元素节点中的索引
- 我今天的收获,必备stadio 插件
- http referer 验证防御方法_渗透测试 跨站攻击防御与安全检测手法剖析
- 《天天数学》连载23:一月二十三日
- 通俗理解TCP握手次数是三次?
- python面试题之你如何管理不同版本的代码?
- StretchBlt()函数使用
- 8月7日科技联播:人民日报发推欢迎Google回归,李彦宏回应非常有信心再赢一次...
- 转:应用级集群系统的设计(下)
- 如何向NCBI上传线粒体基因组序列
- html大作业【NBA篮球介绍 22个页面】学生网页设计源码
- 使用John the ripper破解弱密码
- 浏览器内核控制Meta标签说明文档(360浏览器默认极速模式)
- 为什么我怎么也理解不了波粒二象性,是因为智商不够吗?
- 团体力学理论(1944)--轉
- 马云在大学学计算机,IT大佬高考成绩单:李彦宏是状元 马云数学仅1分
- linux下at的用法,详解Linux系统中at与atq命令的用法
- javascript关于累加和的发散思维
- python 少儿不宜图片识别(基于肤色数量)
- The Lost House POJ - 2057(树形dp+贪心 (双线最优子结构问题))