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 ...
随机推荐
- python学习day4--python基础--购物小程序
'''购物小程序:用户启动时先输入工资用户启动程序后打印商品列表允许用户选择购买商品允许用户不断购买各种商品购买时检测余额是否够,如果够直接扣款,否则打印余额不足允许用户主动退出程序,退出时打印已购商 ...
- C# WCF学习笔记(二)终结点地址与WCF寻址(Endpoint Address and WCF Addressing) WCF中的传输协议
URI的全称是 Uniform Rosource Identifire(统一资源标识),它唯一标识一个确定的网绐资源,同时也表示资源所处的位置及访问的方式(资源访问所用的网络协议). 对于Endpoi ...
- vs2015启动iis express失败
vs2015启动web项目失败,查看日志 IIS Express\aspnetcore.dll 未能加载 ,解决方法 下载 VSorVWDASPNETCore.exe (https://www.asp ...
- HTTP 错误 500.21 - Internal Server Error 处理程序“PageHandlerFactory-Integr
将网站发布到IIS,访问发生如下错误: HTTP 错误 500.21 - Internal Server Error处理程序"PageHandlerFactory-Integr"在 ...
- 断开SVN连接操作方法
SVN是日常项目管理中经常使用到的工具,然而拷贝备份需要与SVN服务器断开连接,具体操作步骤: 1.在桌面建立一个文本文件,取名为kill-svn-folders.reg(扩展名由txt改为reg), ...
- (转)C# 数据类型映射 (SQLite,MySQL,MSSQL,Oracle)
一.C# vs SQLite: C# SQLite 字段名 类型 库类型 GetFieldType(#) 转换 备注 F_BOOL bool BIT NOT NULL Boolean F_BOOL_N ...
- 引用类型之Array类型
Array类型 ECMAScript数组与其它语言数组一样,都是数据的有序列表.但是ECMAScript数组的每一项可以保存任何类型的数据.而且,ECMAScript数组是可以动态调整的. 1.创建和 ...
- 【leetcode】363. Max Sum of Rectangle No Larger Than K
题目描述: Given a non-empty 2D matrix matrix and an integer k, find the max sum of a rectangle in the ma ...
- [zz] 使用ssh公钥密钥自动登陆linux服务器
目录 .生成密匙对 .拷贝公匙到远程机 .启动登陆代理 这种方法处理后每次需要运行命令:ssh-add ~/.ssh/id_dsa 作为一名 linux 管理员,在多台 Linux 服务器上登陆进行远 ...
- JSON的使用
最近在项目中大量的使用了JSON, 发现JSON和XML的功能相近,都是一种数据传输格式.只是与XML相比JSON显得更加轻量级,使用也更加容易. JSON依赖的第三方jar包: commons-be ...