比赛的时候先是受以前一个圣神海的题目 用了两遍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的更多相关文章

  1. HDU 4101 Ali and Baba

    原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=4101 一看之下以为是博弈,后来分析才知道只是搜索题. 首先,我们需要从值为-1的位置由内向外搜索一次, ...

  2. HDU 4101 Ali and Baba (思路好题)

    与其说这是个博弈,倒不如说是个搜索.这题思路不错,感觉很难把情况考虑周全. 在地图外围填充一圈0,两次BFS,第一次从-1点出发,把从-1到达的0点以及包围0的那一圈石头标记出来.如下图: 1 1 1 ...

  3. HDOJ 2111. Saving HDU 贪心 结构体排序

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  4. 【HDU 3037】Saving Beans Lucas定理模板

    http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ...

  5. hdu 4859 海岸线 Bestcoder Round 1

    http://acm.hdu.edu.cn/showproblem.php?pid=4859 题目大意: 在一个矩形周围都是海,这个矩形中有陆地,深海和浅海.浅海是可以填成陆地的. 求最多有多少条方格 ...

  6. HDU 4569 Special equations(取模)

    Special equations Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  7. HDU 4006The kth great number(K大数 +小顶堆)

    The kth great number Time Limit:1000MS     Memory Limit:65768KB     64bit IO Format:%I64d & %I64 ...

  8. HDU 1796How many integers can you find(容斥原理)

    How many integers can you find Time Limit:5000MS     Memory Limit:32768KB     64bit IO Format:%I64d ...

  9. hdu 4481 Time travel(高斯求期望)(转)

    (转)http://blog.csdn.net/u013081425/article/details/39240021 http://acm.hdu.edu.cn/showproblem.php?pi ...

随机推荐

  1. fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏

    为完成老师的任务,用c++写个计算器,又去学点c++,结果就有各种问题,如题 http://www.cnblogs.com/newpanderking/articles/3372969.html 感谢 ...

  2. plsqldev与sqldeveloper

    plsqldev连接 1.连接不同服务器,要修改tnsnames.ora文件,具体如下修改如下位置 # tnsnames.ora Network Configuration File: \app\us ...

  3. Swift静态属性

    在介绍静态属性之前,我们先来看一个类的设计,有一个Account(银行账户)类,假设它有3个属性:amount(账户金额).interestRate(利率)和owner(账户名).在这3个属性中,am ...

  4. block回调具体例子

    //main.m ////  main.m//  回调////  Created by hehe on 15/9/10.//  Copyright (c) 2015年 wang.hehe. All r ...

  5. WMI查看电脑信息,devenv管理自己的解决方案

    最近把公司用的电脑重装了一下,期间用到了驱动精灵,驱动精灵把电脑的全方面信息都显示出来了,让人有种一目了然的感觉,为什么我不自己也写个呢?虽然显示的数据不一定有驱动精灵全单至少是我自己写的,不是吗? ...

  6. 【转】简单理解socket

    题外话 前几天和朋友聊天,朋友问我怎么最近不写博客了,一个是因为最近在忙着公司使用的一些控件的开发,浏览器兼容性搞死人:但主要是因为这段时间一直在看html5的东西,看到web socket时觉得很有 ...

  7. DDL_数据库模式定义语言

    2014年11月22日 15:53:24 DDL 定义  define 概念:是用于描述数据库中要存储的现实世界实体的语言.一个数据库模式包含该数据库中所有实体的描述定义.               ...

  8. 《APUE》第五章笔记

    第五章具体介绍了标准I/O库的各种细节,要是一一列出来,有费精力且可能列不全,故只讲平常多用到的.标准输入输出是由一大批函数组成的. 要记住,标准输入输出是有缓冲的,就是当缓冲区的数据满了的时候,才会 ...

  9. A version is required for an API group definition.

    A version is required for an API group definition.

  10. php 字母大小写转换的函数

    分享下,在php编程中,将字母大小写进行转换的常用函数. 1.将字符串转换成小写strtolower(): 该函数将传入的字符串参数所有的字符都转换成小写,并以小定形式放回这个字符串 2.将字符转成大 ...