【codeforces 404D】Minesweeper 1D
【题目链接】:http://codeforces.com/problemset/problem/404/D
【题意】
让你玩一个1维的扫雷游戏;
游戏的描述由数字0..2以及符号*表示;
分别表示这个格子的相邻的两个格子里面有几个炸弹;以及炸弹;
然后挖一些空;
问你有多少种填满的方案;
【题解】
dp[i][1] 表示前i个位置,第i个位置放0的方案数
dp[i][2] 表示钱i个位置,第i个位置放1,前一位没炸弹的方案数
dp[i][3] …..放1,前一位有炸弹…..
dp[i][4] …..放2….
dp[i][5] ….放炸弹….
根据每一位是什么进行转移就可以了;
转移也很容易想的;
然后初值根据s[1]的值来置;
【Number Of WA】
3
【完整代码】
#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
#define Open() freopen("D:\\rush.txt","r",stdin)
#define Close() ios::sync_with_stdio(0),cin.tie(0)
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 1e6+100;
const int MOD = 1e9+7;
char s[N];
int dp[N][6],ans,n;
inline void add(int &a,int &b){
a+=b;
if (a>=MOD) a-=MOD;
}
int main(){
//Open();
scanf("%s",s+1);
if (s[1]=='0'){
dp[1][1] = 1;
}else if (s[1]=='1'){
dp[1][2] = 1;
}else if (s[1]=='2'){
//dp[1][4] = 1;
}else if (s[1]=='*'){
dp[1][5] = 1;
}else{
dp[1][1] = dp[1][2] = dp[1][5] = 1;
}
n = (int) strlen(s+1);
//dp[i][1] 放0
//dp[i][2] 放1,前一位没炸弹
//dp[i][3] 放1,前一位有炸弹
//dp[i][4] 放2
//dp[i][5] 放炸弹
rep1(i,2,n){
if (s[i]=='0'){
add(dp[i][1],dp[i-1][1]);
add(dp[i][1],dp[i-1][3]);
}else if (s[i]=='1'){
add(dp[i][2],dp[i-1][1]);
add(dp[i][2],dp[i-1][3]);
add(dp[i][3],dp[i-1][5]);
}else if (s[i]=='2'){
add(dp[i][4],dp[i-1][5]);
}else if (s[i]=='*'){
add(dp[i][5],dp[i-1][2]);
add(dp[i][5],dp[i-1][4]);
add(dp[i][5],dp[i-1][5]);
}else if (s[i]=='?'){
add(dp[i][1],dp[i-1][1]);
add(dp[i][1],dp[i-1][3]);
add(dp[i][2],dp[i-1][1]);
add(dp[i][2],dp[i-1][3]);
add(dp[i][3],dp[i-1][5]);
add(dp[i][4],dp[i-1][5]);
add(dp[i][5],dp[i-1][2]);
add(dp[i][5],dp[i-1][4]);
add(dp[i][5],dp[i-1][5]);
}
}
add(ans,dp[n][1]),add(ans,dp[n][3]),add(ans,dp[n][5]);
cout << ans << endl;
return 0;
}
【codeforces 404D】Minesweeper 1D的更多相关文章
- 【codeforces 415D】Mashmokh and ACM(普通dp)
[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...
- 【codeforces 255D】Mr. Bender and Square
[题目链接]:http://codeforces.com/problemset/problem/255/D [题意] 给你一个n*n的方框; 给你一个方块;(以下说的方块都是单位方块) 每一秒钟,可以 ...
- 【codeforces 707E】Garlands
[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...
- 【codeforces 707C】Pythagorean Triples
[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...
- 【codeforces 709D】Recover the String
[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...
- 【codeforces 709B】Checkpoints
[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...
- 【codeforces 709C】Letters Cyclic Shift
[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...
- 【Codeforces 429D】 Tricky Function
[题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ...
- 【Codeforces 670C】 Cinema
[题目链接] http://codeforces.com/contest/670/problem/C [算法] 离散化 [代码] #include<bits/stdc++.h> using ...
随机推荐
- C语言基本语法——数组
一.一维数组 1.什么是数组 2.数组语法 3.下标 4.初始化 5.数组名和数组首地址 二.一维数组的应用 1.数组的赋值与拷贝 2.数组的正反遍历 3.随机数 4.数组乱序 5.数组的重复 三.二 ...
- windows下一台机器运行多个tomcat
一.将本机原有的tomcat配置不变, 二.下载新的tomcat解压版,地址:http://tomcat.apache.org/download-80.cgi 三.下载完成解压后,为了方便区分,最好将 ...
- Vue组件之作用域插槽
写作用域插槽之前,先介绍一下Vue中的slot内容分发: 如果<child-component></child-component>标签之间没有插入那两个p标签的话,页面会显示 ...
- [Codeforces 226E]Noble Knight's Path
题目大意:有一棵n个节点的树,m年.初始每个节点都有.每天有如下操作:1. 给定c,让c没有(c只可能没有一次).2. 给定s,t,k,y,求从第y+1年到现在(即忽略y+1年之前的操作1),s到t的 ...
- BZOJ 3676 [Apio2014]回文串 (后缀自动机+manacher/回文自动机)
题目大意: 给你一个字符串,求其中回文子串的长度*出现次数的最大值 明明是PAM裸题我干嘛要用SAM做 回文子串有一个神奇的性质,一个字符串本质不同的回文子串个数是$O(n)$级别的 用$manach ...
- [luogu 2568] GCD (欧拉函数)
题目描述 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 输入输出格式 输入格式: 一个整数N 输出格式: 答案 输入样例#1: 4 输出样例#1: 4 ...
- 【codeforces 810B】Summer sell-off
[题目链接]:http://codeforces.com/contest/810/problem/B [题意] 每天有ki件物品,你知道每天能卖掉li件; 然后让你选f天; 这f天,可以将ki乘上2; ...
- FastDFS架构
1.什么是 FastDFS FastDFS是用c语言编写的一款开源的分布式文件系统.FastDFS为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并注重高可用.高性能等指标,使用Fas ...
- ACCESS-入门思维导图
ACCESS-入门思维导图 链接:http://pan.baidu.com/s/1bozYiNt 密码:5tly 如果有错误,请告知我!
- node.js mongodb ReplSet
随着web2.0兴起,高并发大数据量的应用对数据库高速响应的性能要求日趋明显,传统的关系型数据库在这方面显得有些乏力.有矛自有盾,内存DB的出现弥补了传统关系型db的不足.眼下市面流行的内存db主要有 ...