UESTC_冬马党 CDOJ 882
冬马党
Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others)
终于到了冬马党与雪菜党决战的时候了,为了方便,他们的决战之地可看成一个n×m矩阵。
决战前夜,冬马党安插在雪菜党中的内线告诉白学家Kuros
,雪菜党已经在他们的决战之地埋下了地雷。
白学家Kuros
根据多年来扫雷的经验,推测出雪菜党一定不会在相邻的格子里都放地雷。(两个格子相邻指它们共享一条边)并且,根据先遣部队的探查,某些格子的土地非常坚硬,是不可能埋地雷的。
为了冬马党最终的胜利,Kuros
想知道,雪菜党总共有多少种方案来放地雷。
Input
输入第一行为两个整数n,m,表示决战之地的大小。(1≤n≤12,1≤m≤12)
接下来n行,每行m个数,0表示该土地不能放地雷,1表示该土地可以埋地雷。
Output
一行,一个整数,表示总的方案数,答案取100000000的余数。
Sample input and output
Sample Input | Sample Output |
---|---|
|
|
Source
- #include <iostream>
- #include <cstring>
- #include <cstdio>
- #include <algorithm>
- typedef long long ll;
- using namespace std;
- const ll mod = ;
- ll f[][ << ];
- bool g[][];
- int n,m,r,cur=;
- void dfs(int pos,int val,ll add)
- {
- if (pos == -)
- f[cur][val] = (f[cur][val] + add) % mod;
- else
- {
- if (val >> pos & || !g[r][pos]) //上一行的这个位置已经放了地雷 / 这个地方不允许放地雷
- dfs(pos-,val & ~( << pos),add);
- else
- {
- dfs(pos-,val | ( << pos),add);
- dfs(pos-,val,add);
- }
- }
- }
- bool check(int x)
- {
- int pre = ;
- for(int i = ; i < m ; ++ i)
- {
- int newx = x >> i & ;
- if (newx && pre)
- return false;
- pre = newx;
- }
- return true;
- }
- int main(int argc,char *argv[])
- {
- memset(g,true,sizeof(g));
- memset(f,,sizeof(f));
- scanf("%d%d",&n,&m);
- for(int i = ; i < n ; ++ i)
- for(int j = ; j < m ; ++ j)
- {
- int temp;
- scanf("%d",&temp);
- if (!temp)
- g[i][j] = false;
- }
- r = ;
- dfs(m-, , );
- for(int i = ; i < n ; ++ i)
- {
- cur ^= ;
- r = i;
- for(int j = ; j < ( << m) ; ++ j) f[cur][j] = ;
- for(int j = ; j < ( << m) ; ++ j)
- if (check(j))
- dfs(m-,j,f[cur^][j]);
- }
- int ans = ;
- for(int i = ; i < ( << m) ; ++ i)
- if (check(i))
- ans = (ans + f[cur][i]) % mod;
- printf("%lld\n",ans % mod);
- return ;
- }
UESTC_冬马党 CDOJ 882的更多相关文章
- UESTC 882 冬马党 --状压DP
定义:dp[i][j]为状态为j时,第i行符合条件的状态数 转移方程:dp[i][j] += dp[i-1][t] //t为上一行状态,与当前行不冲突. 从第一行开始向下枚举,每次枚举当前行的状态 ...
- UESTC_神秘绑架案 CDOJ 881
神秘绑架案 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit Sta ...
- UESTC_方老师买表 CDOJ 885
老师买表 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit Stat ...
- 2014 UESTC暑前集训动态规划专题解题报告
A.爱管闲事 http://www.cnblogs.com/whatbeg/p/3762733.html B.轻音乐同好会 C.温泉旅馆 http://www.cnblogs.com/whatbeg/ ...
- Codeforces 433A (背包)
题面 传送门 真是令人胃疼的题面 我不管,我要把苹果都给雪菜!(滑稽)(冬马党不要打我) 分析 突然感觉这题跟今年NOIP Day1T2有点像,都是根据数加减来构造背包,只不过这题是01背包而不是完全 ...
- 学习进度04(billbill长评数据提取01)
学习了python写入csv文件自己想了一个小实战,爬取billbill<白色相簿>番剧的长评 网页是动态变化的,往下拉他才会更新出长评,找出关键链接https://api.bilibil ...
- UESTC_温泉旅店 CDOJ 878
天空飘下一朵一朵的雪花,这是一片纯白的世界. 在天空之下的温泉旅店里,雪菜已醉倒在一旁,冬马与春希看了看说着梦话的雪菜,决定找一点玩的来度过这愉快的晚上. 这家旅店提供一种特色游戏,游戏有n张牌,各写 ...
- UESTC_摩天轮 2015 UESTC Training for Dynamic Programming<Problem K>
K - 摩天轮 Time Limit: 10000/4000MS (Java/Others) Memory Limit: 262143/262143KB (Java/Others) Submi ...
- 【BZOJ-2892&1171】强袭作战&大sz的游戏 权值线段树+单调队列+标记永久化+DP
2892: 强袭作战 Time Limit: 50 Sec Memory Limit: 512 MBSubmit: 45 Solved: 30[Submit][Status][Discuss] D ...
随机推荐
- 【剑指offer】面试题35:第一个只出现一次的字符
题目: 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符的位置.若为空串,返回-1.(书上是要求返回字符) 思路: 第一遍扫描保存下每个字符出现的 ...
- Spoj1771-Yet Another N-Queen Problem(精确覆盖)
Description After solving Solution to the n Queens Puzzle by constructing, LoadingTime wants to solv ...
- 烟雾检测笔记1--《Video-based smoke detection with histogram sequence of LBP and LBPV pyramids》解析、实现
基于HEP(histograms of equivalent patterns[1])框架下的特征具有良好的纹理分类效果,LBP(local binary patterns[2])属于HEP框架下最常 ...
- shell编程while
脚本编程: 顺序结构 选择结构 if case 循环结构 for while until whil ...
- DoTween学习笔记(二) UGUI结合使用(实现一些简单效果)
UGUI官方实例中是使用Animation来控制UI的移动,放大缩小动画等等, Animation来控制UI的动画工作量实在是太多了, 所以我们一般使用itween,DoTween. 来控制动画, 这 ...
- JVM结构、GC工作机制详解
JVM结构.内存分配.垃圾回收算法.垃圾收集器.下面我们一一来看. 一.JVM结构 根据<java虚拟机规范>规定,JVM的基本结构一般如下图所示: 从左图可知,JVM主要包括四个部分 ...
- Binarized Neural Networks_ Training Neural Networks with Weights and Activations Constrained to +1 or −1
转载请注明出处: http://www.cnblogs.com/sysuzyq/p/6248953.html by 少侠阿朱
- 【桌面虚拟化】之三 Persistent vs NonP
作者:范军 (Frank Fan) 新浪微博:@frankfan7 在[桌面虚拟化]之二类型及案例中我们探讨了桌面虚拟化的两种架构,HostedVirtual Desktop (VDI) 和 Publ ...
- StaggeredGridView+universal-image-loader载入网路图片实现瀑布流
StaggeredGridView 开源lib https://github.com/maurycyw/StaggeredGridView 文章demo下载地址 http://download.c ...
- 使用INTERVAL YEAR TO MONTH类型
Oracle Database 9i数据库引入了一种新特性,可以用来存储时间间隔.时间间隔的例子包括: ● 1年零3个月 ● 25个月 ● -3天5小时16分 ● 1天7小时 ● -56小时 注意: ...