【题目链接】: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;
}

最新文章

  1. 机器学习——k-近邻算法
  2. RESTful API URI 设计: 判断资源是否存在?
  3. gdutcode 1195: 相信我这是水题 GDUT中有个风云人物pigofzhou,是冰点奇迹队的主代码手,
  4. asp.net 导入excel文件
  5. Java 反射 getDeclareFields getModifiers setAccessible(true)
  6. 解决:“java.lang.IllegalArgumentException: error at ::0 can&#39;t find referenced pointcut myMethod”问题!
  7. FIR系统的递归与非递归实现
  8. eclipse快捷键使用
  9. &lt;Chapter 2&gt;2-2-1.用户偏好模式(The User Preferences Pattern)
  10. javascript 拖放效果
  11. Program Files 与Program Files (x86)
  12. Nest客户端的基本使用方法
  13. mybatis源码解读(四)——事务的配置
  14. 【.NET异步编程系列1】:await&amp;async语法糖让异步编程如鱼得水
  15. VMWare安装Mac系统后无法全屏显示的问题
  16. ios unicode
  17. docker下centos安装ping命令
  18. [cpu]cpu unused pin应该怎样从硬件和软件上处理
  19. 浏览器根对象navigator之客户端检测
  20. laravel 多图上传

热门文章

  1. 【XSY2689】王子 - 网络流
  2. python3三级菜单的访问,并按q退出
  3. PHP中的 Iterator 与 Generator
  4. 紫书 例题8-2 UVa 11605(构造法)
  5. static和extern的作用域--题目
  6. Collection、List、Set、Map之间的关系
  7. cogs 304. [NOI2001] 方程的解数(meet in the middle)
  8. poj2492--A Bug&amp;#39;s Life(并查集变形)
  9. [iOS]字符串转字典
  10. 黑马day14 过滤器概述&amp;amp;生命周期&amp;amp;运行过程