hdu 4101
比赛的时候先是受以前一个圣神海的题目 用了两遍DFS 第一遍标记出围墙 第二遍求围墙外和每块围墙降为1所需的攻击次数 结果爆栈 改为BFS后AC
DFS的加了一句这个 #pragma comment(linker, "/STACK:1024000000,1024000000") 就解决了爆栈问题
然后就是比赛的时候写了一个bug 竟然过了
//dfs#include <iostream>
#include <fstream>
#include <cstring>
#pragma comment(linker, "/STACK:1024000000,1024000000")
using namespace std;
int dx[5] = {1, -1, 0, 0}, dy[5] = {0, 0, 1, -1};
int g[310][310],sum,n,m;
bool vis[310][310],ok,dd[310][310];
void init()
{
memset(g, 0, sizeof(g));
sum = 0;
ok = false;
memset(vis, 0, sizeof(vis));
memset(dd, 0, sizeof(dd));
}
bool cc(int x, int y)
{
if(x >= 1 && x <= n && y >= 1 && y <= m)
return true;
return false;
}
void dfs(int x, int y)
{
vis[x][y] = 1;
if(x == 1 || x == n || y == 1 || y == m)
ok = true;
for(int i = 0; i < 4; i++)
{
int nx = x+dx[i], ny = y+dy[i];
if(cc(nx, ny) && !vis[nx][ny])
{
if(g[nx][ny] == 0)
{
dfs(nx, ny);
}
else
{
dd[nx][ny] = 1;
}
}
}
}
void dfs2(int x, int y)
{
for(int i = 0; i < 4; i++)
{
int nx = x+dx[i], ny = y+dy[i];
if(cc(nx, ny) && !vis[nx][ny])
{
if(!dd[nx][ny])
{
sum += g[nx][ny];
vis[nx][ny] = 1;
dfs2(nx, ny);
}
else
{
vis[nx][ny] = 1;
sum += g[nx][ny] -1;
}
}
}
}
int main(void)
{
int _x,_y;
while(scanf("%d%d",&n,&m) == 2)
{
init();
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
{
scanf("%d",&g[i][j]);
if(g[i][j] == -1)
_x = i, _y = j;
}
dfs(_x, _y);
if(ok)
{
printf("Ali Win\n");
}
else
{
memset(vis, 0, sizeof(vis));
for(int i = 1; i <= n; i++)
{
if(!dd[i][1] && !vis[i][1])
{
vis[i][1] = 1;
sum += g[i][1];
dfs2(i, 1);
}
else if(dd[i][1] && !vis[i][1])
{
vis[i][1] = 1;
sum += g[i][1]-1;
}
if(!dd[i][m] && !vis[i][m])
{
vis[i][m] = 1;
sum += g[i][m];
dfs2(i, m);
}
else if(dd[i][m] && !vis[i][m])
{
vis[i][m] = 1;
sum += g[i][m]-1;
}
}
for(int i = 1; i <= m; i++)
{
if(!dd[1][i] && !vis[1][i])
{
vis[1][i] = 1;
sum += g[1][i];
dfs2(1, i);
}
else if(dd[1][i] && !vis[1][i])
{
vis[1][i] = 1;
sum += g[1][i]-1;
}
if(!dd[n][i] && !vis[n][i])
{
vis[n][i] = 1;
sum += g[n][i];
dfs2(n, i);
}
else if(dd[n][i] && !vis[n][i])
{
vis[n][i] = 1;
sum += g[n][i]-1;
}
}
// printf("%d\n",sum);
if(sum%2)
printf("Ali Win\n");
else
printf("Baba Win\n");
}
}
return 0;
}
#include <iostream>
#include <fstream>
#include <cstring>
#include <queue>
using namespace std;
int dx[5] = {1, -1, 0, 0}, dy[5] = {0, 0, 1, -1};
int g[310][310],sum,n,m;
bool vis[310][310],ok,dd[310][310];
void init()
{
memset(g, 0, sizeof(g));
sum = 0;
ok = false;
memset(vis, 0, sizeof(vis));
memset(dd, 0, sizeof(dd));
}
bool cc(int x, int y)
{
if(x >= 1 && x <= n && y >= 1 && y <= m)
return true;
return false;
}
bool cc2(int x, int y)
{
if(x >= 0 && x <= n+1 && y >= 0 && y <= m+1)
return true;
return false;
}
void dfs(int x, int y)
{
queue<int> Q;
int u = m*x+y;
Q.push(u);
while(!Q.empty())
{
u = Q.front();
Q.pop();
x = (u-1)/m, y = u%m == 0 ? m:u%m;
if(x == 1 || x == n || y ==1 || y == m)
ok = true;
vis[x][y] = 1;
for(int i = 0; i < 4; i++)
{
int nx = x+dx[i], ny = y+dy[i];
if(cc(nx, ny) && !vis[nx][ny])
{
if(g[nx][ny] == 0)
{
int v = nx*m+ny;
Q.push(v);
}
else
{
vis[nx][ny] = 1;
dd[nx][ny] = 1;
}
}
}
}
} void dfs2(int x, int y)
{
vis[x][y] = 1;
queue<int> Q;
int u = (m+2)*x+y;
Q.push(u);
while(!Q.empty())
{
u = Q.front();
Q.pop();
x = u/(m+2), y = u%(m+2);
for(int i = 0; i < 4; i++)
{
int nx = x+dx[i], ny = y+dy[i];
if(cc2(nx, ny) && !vis[nx][ny])
{
if(!dd[nx][ny])
{
sum += g[nx][ny];
vis[nx][ny] = 1;
int v = nx*(m+2)+ny;
Q.push(v);
}
else
{
vis[nx][ny] = 1;
sum += g[nx][ny] -1;
}
}
}
}
}
int main(void)
{
int _x,_y;
while(scanf("%d%d",&n,&m) == 2)
{
init();
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
{
scanf("%d",&g[i][j]);
if(g[i][j] == -1)
_x = i, _y = j;
}
dfs(_x, _y);
if(ok)
{
printf("Ali Win\n");
}
else
{
memset(vis, 0, sizeof(vis));
dfs2(0, 0);
// printf("%d\n",sum);
if(sum%2)
printf("Ali Win\n");
else
printf("Baba Win\n");
}
}
return 0;
}
#include <iostream>
#include <fstream>
#include <cstring>
#include <queue>
using namespace std;
int dx[5] = {1, -1, 0, 0}, dy[5] = {0, 0, 1, -1};
int g[310][310],sum,n,m;
bool vis[310][310],ok,dd[310][310];
void init()
{
memset(g, 0, sizeof(g));
sum = 0;
ok = false;
memset(vis, 0, sizeof(vis));
memset(dd, 0, sizeof(dd));
}
bool cc(int x, int y)
{
if(x >= 1 && x <= n && y >= 1 && y <= m)
return true;
return false;
}
void dfs(int x, int y)
{
queue<int> Q;
int u = m*x+y;
Q.push(u);
while(!Q.empty())
{
u = Q.front();
Q.pop();
x = (u-1)/m, y = u%m == 0 ? m:u%m;
if(x == 1 || x == n || y ==1 || y == m)
ok = true;
vis[x][y] = 1;
for(int i = 0; i < 4; i++)
{
int nx = x+dx[i], ny = y+dy[i];
if(cc(nx, ny) && !vis[nx][ny])
{
if(g[nx][ny] == 0)
{
int v = nx*m+ny;
Q.push(v);
}
else
{
vis[nx][ny] = 1;
dd[nx][ny] = 1;
}
}
}
}
} void dfs2(int x, int y)
{
vis[x][y] = 1;
queue<int> Q;
int u = m*x+y;
Q.push(u);
while(!Q.empty())
{
u = Q.front();
Q.pop();
x = (u-1)/m, y = u%m == 0 ? m:u%m;
for(int i = 0; i < 4; i++)
{
int nx = x+dx[i], ny = y+dy[i];
if(cc(nx, ny) && !vis[nx][ny])
{
if(!dd[nx][ny])
{
sum += g[nx][ny];
vis[nx][ny] = 1;
int v = nx*m+ny;
Q.push(v);
}
else
{
vis[nx][ny] = 1;
sum += g[nx][ny] -1;
}
}
}
}
}
int main(void)
{
int _x,_y;
while(scanf("%d%d",&n,&m) == 2)
{
init();
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
{
scanf("%d",&g[i][j]);
if(g[i][j] == -1)
_x = i, _y = j;
}
dfs(_x, _y);
if(ok)
{
printf("Ali Win\n");
}
else
{
memset(vis, 0, sizeof(vis));
for(int i = 1; i <= n; i++)
{
if(!dd[i][1] && !vis[i][1])
{
vis[i][1] = 1;
sum += g[i][1];
dfs2(i, 1);
}
else if(dd[i][1] && !vis[i][1])
{
vis[i][1] = 1;
sum += g[i][1]-1;
}
if(!dd[i][m] && !vis[i][m])
{
vis[i][m] = 1;
sum += g[i][m];
dfs2(i, m);
}
else if(dd[i][m] && !vis[i][m])
{
vis[i][m] = 1;
sum += g[i][m]-1;
}
}
for(int i = 1; i <= m; i++)
{
if(!dd[1][i] && !vis[1][i])
{
vis[1][i] = 1;
sum += g[1][i];
dfs2(1, i);
}
else if(dd[1][i] && !vis[1][i])
{
vis[1][i] = 1;
sum += g[1][i]-1;
}
if(!dd[n][i] && !vis[n][i])
{
vis[n][i] = 1;
sum += g[n][i];
dfs2(n, i);
}
else if(dd[n][i] && !vis[n][i])
{
vis[n][i] = 1;
sum += g[n][i]-1;
}
}
// printf("%d\n",sum);
if(sum%2)
printf("Ali Win\n");
else
printf("Baba Win\n");
}
}
return 0;
}
hdu 4101的更多相关文章
- HDU 4101 Ali and Baba
原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=4101 一看之下以为是博弈,后来分析才知道只是搜索题. 首先,我们需要从值为-1的位置由内向外搜索一次, ...
- HDU 4101 Ali and Baba (思路好题)
与其说这是个博弈,倒不如说是个搜索.这题思路不错,感觉很难把情况考虑周全. 在地图外围填充一圈0,两次BFS,第一次从-1点出发,把从-1到达的0点以及包围0的那一圈石头标记出来.如下图: 1 1 1 ...
- HDOJ 2111. Saving HDU 贪心 结构体排序
Saving HDU Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- 【HDU 3037】Saving Beans Lucas定理模板
http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ...
- hdu 4859 海岸线 Bestcoder Round 1
http://acm.hdu.edu.cn/showproblem.php?pid=4859 题目大意: 在一个矩形周围都是海,这个矩形中有陆地,深海和浅海.浅海是可以填成陆地的. 求最多有多少条方格 ...
- HDU 4569 Special equations(取模)
Special equations Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
- HDU 4006The kth great number(K大数 +小顶堆)
The kth great number Time Limit:1000MS Memory Limit:65768KB 64bit IO Format:%I64d & %I64 ...
- HDU 1796How many integers can you find(容斥原理)
How many integers can you find Time Limit:5000MS Memory Limit:32768KB 64bit IO Format:%I64d ...
- hdu 4481 Time travel(高斯求期望)(转)
(转)http://blog.csdn.net/u013081425/article/details/39240021 http://acm.hdu.edu.cn/showproblem.php?pi ...
随机推荐
- 在web界面调用水晶报表导出文件时莫名错误
原因是水晶报表未破解版有字段限制,不能超过90(具体个数没仔细测)个字段. 建议那些select *的朋友检查一下字段个数
- android代码设置、打开WLAN wifi热点及热点的连接
其实创建热点很简单,先获取到wifi的服务,再配置热点名称.密码等等,然后再通过反射打开它就OK了. 下面我们看看创建热点的代码实现: 这一段是开启WLAN热点,并可以指定好它的热点名和密码 支行后, ...
- c++ 11 国标标准方面的异常处理与微软在Visual Studio 2012的异常处理的区别
这段代码: __try { } __except(GetErrorCode()) { } 可以捕获空指针,但是包围在其中的代码不能有自带析构函数的对象.c++ 11 标准里面的auto_ptr关键字, ...
- Yii Framework处理网站前后台文件的方法
此方法参考官方网站的cookbook,详细请看http://www.yiiframework.com/doc/cookbook/33/, 我在此基础上做了一些改动,人个感觉非常棒了,大家可以试一下! ...
- javascript笔记——cookie解析
JavaScript中的另一个机制:cookie,则可以达到真正全局变量的要求. cookie是浏览器 提供的一种机制,它将document 对象的cookie属性提供给JavaScript.可以由J ...
- day 0.
/* 嗯 就要结束了. OI生涯 2015.12-2016.11. 认识了很多人. 然后我这个学渣跟你们混在一起 感觉自卑至极啊. 好了 先不说这些伤心的话. Gryz小伙伴儿们NOIP RP++吧. ...
- cplusplus解析
经常在头文件包含代码里面看到如下代码 #ifndef MAC_API_H #define MAC_API_H #ifdef __cplusplus extern "C"{ #end ...
- IIS6,IIS7 最简单的重写URL
虽然现在很少用IIS6,今天突然要把项目搬到老的服务器上(IIS6),对项目还要重新部署一下. 主要把时间花在了对url的重写上.其实很简单,如下: IIS6 网站 → 属性 → 主目录 → 配置 → ...
- android 打开GPS的几种方式
1.在讨论打开gps的之前先看下如何检测gps的开关情况: 方式一: boolean gpsEnabled = locationManager.isProviderEnabled(LocationMa ...
- ZENCART 打开/关闭日志文件
优秀的php开源程序很多都只带生成日志文件的功能,这类功能的开发可以帮助到站长在调试网站的时候及时的改正网站存在的错误,但是这类错误日志由来并非网站出现什么严重不可挽救的错误,大部分是一些未定义变量这 ...