HDU 5965 三维dp 或 递推
题意:= =中文题
思路一:比赛时队友想的。。。然后我赛后想了一下想了个2维dp,但是在转移的时候,貌似出了点小问题...吧?然后就按照队友的思路又写了一遍。
定义dp[i][j][k],表示第i列,放j个,剩下k个的种类数。其中j<=2, k<=2,j<=2的来源是只往上、下放。然后状态转移就是
dp[i][j][a[i] - j - k] = (dp[i][j][a[i] - j - k] + p[j] * dp[i - 1][k][j]) % mod;
//看看会不会爆int!数组会不会少了一维!
//取物问题一定要小心先手胜利的条件
#include <bits/stdc++.h>
using namespace std;
#pragma comment(linker,"/STACK:102400000,102400000")
#define LL long long
#define ALL(a) a.begin(), a.end()
#define pb push_back
#define mk make_pair
#define fi first
#define se second
#define haha printf("haha\n")
/*
定义dp[i][j][k]表示第i个人放了j个剩下k个的种类数 */
const LL mod = ;
const int maxn = 1e4 + ;
LL dp[maxn][][];
char ch[maxn];
int a[maxn];
int n;
LL p[] = {, , }; LL solve(){
memset(dp, , sizeof(dp));
for (int i = ; i <= ; i++) {
if (a[] - i > ) continue;
if (a[] - i < ) break;
dp[][i][a[] - i] = p[i];
}
for (int i = ; i <= n; i++){
for (int j = ; j <= ; j++){
for (int k = ; k <= ; k++){
if (a[i] - j - k > ) continue;
if (a[i] - j - k < ) break;///目前放入j个,dp[i-1]剩下j个
dp[i][j][a[i] - j - k] = (dp[i][j][a[i] - j - k] + p[j] * dp[i - ][k][j]) % mod;
}
}
}
LL ans = ;
for (int i = ; i <= ; i++){
if (i > a[n]) break;
ans = (ans + dp[n][i][]) % mod;
}
return ans;
} int main(){
int t; scanf("%d", &t);
while (t--){
scanf("%s", ch);
n = strlen(ch);
bool flag = true;
for (int i = ; ch[i] != '\0'; i++){
a[i + ] = ch[i] - '';
if ((i == || i == n - ) && ch[i] > ''){
flag = false; break;
}
if (ch[i] > '') {
flag = false; break;
}
}
if (!flag) {
printf("0\n"); continue;
}
printf("%I64d\n", solve());
}
return ;
}
思路二:递推
和之前的dp类似,我们定义每次每次都只能往列上放,因此最多只能放两个。然后我们发现,如果第一个位置的地雷数确定了,后面所有的都确定了,那么我们只需要枚举一下,就有答案了
//看看会不会爆int!数组会不会少了一维!
//取物问题一定要小心先手胜利的条件
#include <bits/stdc++.h>
using namespace std;
#pragma comment(linker,"/STACK:102400000,102400000")
#define LL long long
#define ALL(a) a.begin(), a.end()
#define pb push_back
#define mk make_pair
#define fi first
#define se second
#define haha printf("haha\n")
const int maxn = 1e4 + ;
const LL mod = ;
LL dp[maxn];
char ch[maxn];
int a[maxn];
int n;
int p[] = {, , }; LL solve(){
LL ans = ;
for (int i = ; i <= && i <= a[]; i++){
if (a[] - i > ) continue;
dp[] = a[] - i;
for (int j = ; j <= n; j++){
dp[j] = a[j - ] - dp[j - ] - dp[j - ];
}
if (dp[n] + dp[n - ] != a[n]) continue;
LL res = ;
for (int j = ; j <= n; j++){
res = res * p[dp[j]];
if (res > mod) res %= mod;
}
ans = (ans + res) % mod;
}
return ans;
} int main(){
int t; cin >> t;
while (t--){
scanf("%s", ch);
n = strlen(ch);
bool flag = true;
for (int i = ; i < n; i++){
if ((i == || i == n-) && ch[i] > ''){
flag = false; break;
}
if (ch[i] > ''){
flag = false; break;
}
a[i + ] = ch[i] - '';
}
if (!flag) {
printf("0\n"); continue;
}
printf("%I64d\n", solve());
}
return ;
}
HDU 5965 三维dp 或 递推的更多相关文章
- 题解报告:hdu 2084 数塔(递推dp)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2084 Problem Description 在讲述DP算法的时候,一个经典的例子就是数塔问题,它是这 ...
 - [AHOI2009]中国象棋    DP,递推,组合数
		
DP,递推,组合数 其实相当于就是一个递推推式子,然后要用到一点组合数的知识 一道很妙的题,因为不能互相攻击,所以任意行列不能有超过两个炮 首先令f[i][j][k]代表前i行,有j列为一个炮,有k列 ...
 - UVa 926【简单dp,递推】
		
UVa 926 题意:给定N*N的街道图和起始点,有些街道不能走,问从起点到终点有多少种走法. 很基础的dp.递推,但是有两个地方需要注意,在标记当前点某个方向不能走时,也要同时标记对应方向上的对应点 ...
 - hdu 1284 钱币兑换问题 (递推 || DP || 母函数)
		
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
 - HDU 5950 Recursive sequence 【递推+矩阵快速幂】 (2016ACM/ICPC亚洲区沈阳站)
		
Recursive sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Other ...
 - 【BZOJ4944】【NOI2017】泳池 概率DP 常系数线性递推 特征多项式 多项式取模
		
题目大意 有一个\(1001\times n\)的的网格,每个格子有\(q\)的概率是安全的,\(1-q\)的概率是危险的. 定义一个矩形是合法的当且仅当: 这个矩形中每个格子都是安全的 必须紧贴网格 ...
 - [NOI2017]泳池——概率DP+线性递推
		
[NOI2017]泳池 实在没有思路啊~~~ luogu题解 1.差分,转化成至多k的概率减去至多k-1的概率.这样就不用记录“有没有出现k”这个信息了 2.n是1e9,感觉要递推然后利用数列的加速技 ...
 - HDU 5322 Hope ——NTT 分治 递推
		
发现可以推出递推式.(并不会) 然后化简一下,稍有常识的人都能看出这是一个NTT+分治的情况. 然而还有更巧妙的方法,直接化简一下递推就可以了. 太过巧妙,此处不表,建议大家找到那篇博客. 自行抄写 ...
 - lightoj 1126 - Building Twin Towers(dp,递推)
		
题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1126 题解:一道基础的dp就是简单的递推可以设dp[height_left][ ...
 
随机推荐
- Struts2第一天
			
Struts2第一天 整体课程安排:3天知识点+2天练习 第一天:入门(action和result结果集)--一般的请求+响应 第二天:请求数据处理相关(参数接收.类型转换.合法性校验.国际化) 第三 ...
 - ELK配置说明及个人理解
			
ELK是开源的日志查询系统,由三个开源工具组成:Elasticsearch.Logstash和Kibana; Elasticsearch的功能主要用于进行日志数据的存储及查询. Logstash提供日 ...
 - tomcat bio nio apr 模式性能测试
			
转自:tomcat bio nio apr 模式性能测试与个人看法 11.11活动当天,服务器负载过大,导致部分页面出现了不可访问的状态.那后来主管就要求调优了,下面是tomcat bio.nio.a ...
 - git 和 svn
			
GIT和SVN之间的五个基本区别 如果你在读这篇文章,说明你跟大多数开发者一样对GIT感兴趣,如果你还没有机会来试一试GIT,我想现在你就要了解它了. GIT不仅仅是个版本控制系统,它也是个内容管理系 ...
 - CentOS安装Ruby组件
			
ruby安装#安装ruby组件yum install ruby ruby-irb ruby-devel rubygems rpm-build -y#安装Apache服务器yum install htt ...
 - AnimatorController动画遮罩
			
游戏中,我们的人物在某些时候,可能在一个时间点在做两件事,这样就需要同时播放两个动画,但我们肯定不能简单将其叠加,比如移动着开枪.攻击.挥手等等,那么在Unity中我们应该怎样实现这样的功能呢?且听我 ...
 - Openjudge-计算概论(A)-回文串判断
			
描述: 任意给定一个非空的字符串,判断其是否是回文串.回文串是指正向看和反向看均相等的串,如AbcDcbA和cDDc.如果是回文串,则输出1,否则,输出0 输入长度不小于1不大于100的字符串输出如果 ...
 - Sublime Text学习笔记
			
1.快捷键(Key Bindings) Preferences -> Key Bindings ->Default 会打开一个配置文件,里面全是配置信息 2.代码片段(Snippe ...
 - 【Machine Learning in Action --4】朴素贝叶斯从个人广告中获取区域倾向
			
背景:广告商往往想知道关于一个人的一些特定人口统计信息,以便能更好地定向推销广告. 我们将分别从美国的两个城市中选取一些人,通过分析这些人发布的信息,来比较这两个城市的人们在广告用词上是否不同.如果结 ...
 - SpringMVc上传excel或csv文件
			
1.JSP页面代码 <form enctype=""multipart/form-data" method="post"> <inp ...