bzoj 1088 [SCOI2005] 扫雷
SCOI2005 扫雷
一道很有趣的(水)题
“这道题有四种解法,你知道么”
给你矩阵的第二列的数字,求出第一列雷有多少种可能的摆法。
不懂扫雷规则的自行按win+R然后输入winmine
思考过后我想到了一种拙劣的DP写法 ,
四维 F[i][][][] i代表到了第几个格子,后面三维用 0和1表示 这个格子旁边雷的情况,分别是 左上 左 左下
简单易懂(十分恶心)的代码
#include<bits/stdc++.h>
using namespace std;
int N,a[],f[][][][];
int main()
{
ios::sync_with_stdio(false);
cin>>N;
for(int i=;i<=N;i++)cin>>a[i];
if (a[]==)f[][][][]=;
else if (a[]==)f[][][][]=,f[][][][]=;
else if (a[]==)f[][][][]=;
for(int i=;i<=N-;i++)
{
if (a[i]==)
f[i][][][]=f[i-][][][]+f[i-][][][];
else if (a[i]==)
f[i][][][]=f[i-][][][]+f[i-][][][],
f[i][][][]=f[i-][][][]+f[i-][][][],
f[i][][][]=f[i-][][][]+f[i-][][][];
else if (a[i]==)
f[i][][][]=f[i-][][][]+f[i-][][][],
f[i][][][]=f[i-][][][]+f[i-][][][],
f[i][][][]=f[i-][][][]+f[i-][][][];
else if (a[i]==)
f[i][][][]=f[i-][][][]+f[i-][][][];
}
if (a[N]==) cout<<f[N-][][][]+f[N-][][][];
else if (a[N]==) cout<<f[N-][][][]+f[N-][][][]+f[N-][][][]+f[N-][][][];
else if (a[N]==) cout<<f[N-][][][]+f[N-][][][];
return ;
}
就是枚举出了所有的情况 ,暴力转移。 (手边要有个画图板 边写边画 别漏情况)
美其名曰DP
当时代码写得十分顺,一遍过编译 ,一遍AC
实际上 ,没这么复杂。
现在我们可以思考一下 , 第二列数字都已知 , 如果你知道了第一列的前两个格子是否有雷 ,那么 我们就可以把 所有的 都推出来了
b[i]=a[i-1]-b[i-1]-b[i-2] (b[i]是格子i的雷,a[i]是第二列的数字)
所以只要枚举前两个格子的雷就可以了 。
这题答案只有 0,1,2;
超短代码↓
#include<bits/stdc++.h>
using namespace std;
int N,a[],ans;
void Work(int x,int y)
{
int b[];
b[]=x,b[]=y;
for(int i=;i<=N+;i++)
b[i]=a[i-]-b[i-]-b[i-];
if(b[N+]==)ans++;
}
int main()
{
ios::sync_with_stdio(false);
cin>>N;
for(int i=;i<=N;i++)cin>>a[i];
if (a[]==)Work(,),Work(,);
else if (a[]==)Work(,);
else if (a[]==)Work(,);
cout<<ans<<endl;
return ;
}
bzoj 1088 [SCOI2005] 扫雷的更多相关文章
- Bzoj 1088: [SCOI2005]扫雷Mine (DP)
Bzoj 1088: [SCOI2005]扫雷Mine 怒写一发,算不上DP的游戏题 知道了前\(i-1\)项,第\(i\)项会被第二列的第\(i-1\)得知 设\(f[i]\)为第一列的第\(i\) ...
- 【递推】BZOJ 1088: [SCOI2005]扫雷Mine
1088: [SCOI2005]扫雷Mine Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2275 Solved: 1328[Submit][St ...
- bzoj 1088: [SCOI2005]扫雷Mine
题目链接 1088: [SCOI2005]扫雷Mine Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2525 Solved: 1495[Submi ...
- BZOJ 1088: [SCOI2005]扫雷Mine【思维题,神奇的模拟+枚举】
1088: [SCOI2005]扫雷Mine Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3791 Solved: 2234[Submit][St ...
- 【BZOJ】1088: [SCOI2005]扫雷Mine
1088: [SCOI2005]扫雷Mine Description 相 信大家都玩过扫雷的游戏.那是在一个n*m的矩阵里面有一些雷,要你根据一些信息找出雷来.万圣节到了,“余”人国流行起了一种简单的 ...
- 1088: [SCOI2005]扫雷Mine
1088: [SCOI2005]扫雷Mine Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1635 Solved: 979[Submit][Sta ...
- 【BZOJ】1088: [SCOI2005]扫雷Mine(递推)
http://www.lydsy.com/JudgeOnline/problem.php?id=1088 脑残去想递推去了... 对于每一个第二列的格子,考虑多种情况,然后转移.....QAQ 空间可 ...
- 1088. [SCOI2005]扫雷Mine【网格DP】
Description 相信大家都玩过扫雷的游戏.那是在一个n*m的矩阵里面有一些雷,要你根据一些信息找出雷来.万圣节到了 ,“余”人国流行起了一种简单的扫雷游戏,这个游戏规则和扫雷一样,如果某个格子 ...
- BZOJ 1088 扫雷Mine
今天做了几道BZOJ的题,发现统观题目时还是很多很多都不会的,不过还是有几道时可以作的,以后要慢慢加强,争取多做题 BZOJ 1088 扫雷 其实本人平常不大玩扫雷的,就算玩也不是很好,不过看n*2的 ...
随机推荐
- BZOJ 2301 莫比乌斯函数+分块
思路: 同BZOJ1101 就是加个容斥 - http://blog.csdn.net/qq_31785871/article/details/54340241 //By SiriusRen #inc ...
- 唯品会API网关设计与实践--转
原文地址:https://609518.kuaizhan.com/86/70/p4108366952248f 刘璟宇Leo 唯品会资深研发工程师,在大型高性能分布式系统设计和开发方面有丰富的经验.目前 ...
- calender怎么获取每周的周日(给每周的周日特定时间点设置定时)
获取每周的周日 //如果是周日,特殊处理.老外的周日-周六为一周 calendarTemp.add(Calendar.WEEK_OF_MONTH,1); calendarTemp.set(Calend ...
- CSS3的常用属性(一)
选择器 属性选择器(通过标签属性来选择) E[attr]: 表示只要元素<E>存在属性attr就能被选中 如: div[class] E[attr=val]: 表示元素<E> ...
- jQuery学习(二)——使用JQ完成页面定时弹出广告
1.JQuery效果 2.步骤分析: 第一步:引入jQuery相关的文件 第二步:书写页面加载函数 第三步:在页面加载函数中,获取显示广告图片的元素. 第四步:设置定时操作(显示广告图片的函数) 第五 ...
- Enable .Net 4.5 in IIS on Windows 8.1
Setting up a new development box for myself I had forgotten all about the necessity to use theaspnet ...
- js获取当前根目录的方法
function getRootPath_web() { //获取当前网址,如: http://localhost:8083/uimcardprj/share/meun.jsp var curWwwP ...
- python 中i++、逻辑表达式
参考链接:https://www.cnblogs.com/yupeng/p/3345946.html i++运算符 python中没有类似i++之类实现+1的运算符,但是有++i,+-i.之类的,他们 ...
- codeforces248(div1) B Nanami's Digital Board
q次询问,每次询问能够对矩阵某一个值改变(0变1.1变0) 或者是查询子矩阵的最大面积,要求这个这个点在所求子矩阵的边界上,且子矩阵各店中全为1 用up[i][j]表示(i,j)这个点向上能走到的最长 ...
- CSS透明度设置支持IE,Chrome,Firefox浏览器
CSS文件里设置例如以下就可以 filter:alpha(opacity=60); //支持IE opacity:0.6; //支持Chrome.Firefox