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 ...
随机推荐
- UML——类和对象
- SQL 的一个技巧
遇到一个需求,项目是我接手二次开发的,之前的大神设计数据库,订单表中没有订单号,现在让我加上这个号,规则是订单创建日期加上自增的ID,ID需要补足5位,例:00002,00124,01245这样.这个 ...
- HTML+CSS学习笔记 (7) - CSS样式基本知识
HTML+CSS学习笔记 (7) - CSS样式基本知识 内联式css样式,直接写在现有的HTML标签中 CSS样式可以写在哪些地方呢?从CSS 样式代码插入的形式来看基本可以分为以下3种:内联式.嵌 ...
- spring @Resource和@Autowired的区别
@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了.@Resource有两个属性是比较重要的,分 ...
- Java 数组基础,java.util.Arrays
定义数组 方式1(推荐,更能表明数组类型) 方式2(同C语言) 方式3定义时直接初始化 数组运用基础 数组长度 equals() 数组元素不为基本数据类型时 二维数组 二维数组基础 变长的二维数组 j ...
- 《RHEL6.3 FTP服务器虚拟用户的配置(含图)》——如此简单
虚拟用户就是传说中的ftp服务vip用户,大致分为这么几步: 1.安装ftp软件包 yum install *ftp* 2.启动vsftpd服务 /etc/init.d/vsftpd restart ...
- 获取当前<script>节点
/* get current JavaScript dom object. */ var all_js = document.getElementsByTagName("script&quo ...
- 解决xtraFinder在EI下不能使用问题
在EI (10.11)下,由于SIP(System Integrity Protection)机制,导致一些第三方插件不能使用,如xtrafinder. 要想使用,在目前的情况下,启用的方法:一种是安 ...
- nrm —— 快速切换 NPM 源 (附带测速功能)
以前我们介绍过cnpmjs.org和最近推出的淘宝 npm 两个 NPM 镜像.除此之外,还有一些国外的 NPM 镜像.不同地区访问不同的镜像速度可能有差异,然后各个镜像各自都可能有少数包暂时没有同步 ...
- 手把手教你写LKM rookit! 之 第一个lkm程序及模块隐藏(一)
唉,一开始在纠结起个什么名字,感觉名字常常的很装逼,于是起了个这<手把手教你写LKM rookit> 我觉得: 你们觉得:...... 开始之前,我们先来理解一句话:一切的操作都是系统调用 ...