题目大意:给你一个地图0代表可以通过1代表不可以通过。只要能从第一行走到最后一行,那么中国与印度是可以联通的。现在给你q个点,每年风沙会按顺序侵蚀这个点,使改点不可通过。问几年后中国与印度不连通。若一直联通输出-1.

题目思路:看数据这道题就是卡时间的,我们的基本思路是每当风沙侵蚀一个点,我们就进行一次广搜,看看图上下是否联通,我们应尽可能的去优化这个过程。

所以我们可以在遍历年的时候用二分查找:

若当年图可以上下联通,则继续向右查找

若当年图上下无法联通,则向左查找

剪枝:

为了省时间我们应该剪去一些不必要走的路径:假设第一行的x点在第n年已经不可达到最后一行,那么我们就标记一下,在m(m>n)年时,不对x点经行广搜。

具体看代码:

#include<cstdio>
#include<stdio.h>
#include<cstdlib>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<vector>
#include<queue>
#define INF 0x3f3f3f3f
#define MAX 1000005
#define mod 1000000007 using namespace std;
struct node
{
int x,y;
};
char Map[][];
int vis[][],n,m,q,a[MAX],b[MAX],book[MAX],v[][]= {{,},{-,},{,},{,-}},Stack[MAX]; int check(int x,int y)
{
if(x>= && x<n && y>= && y<m && !vis[x][y] && Map[x][y]=='')
return ;
return ;
} int BFS(int x,int y)
{
vis[x][y]=;
node now,next;
now.x=x;
now.y=y;
queue<node>Q;
Q.push(now);
while(!Q.empty())
{
now=Q.front();
Q.pop();
if(now.x==n-)
{
return ;
}
for(int i=; i<; i++)
{
next.x=now.x+v[i][];
next.y=now.y+v[i][];
if(check(next.x,next.y))
{
vis[next.x][next.y]=;
Q.push(next);
}
}
}
return ;
} int main()
{
int T,i,j,ans,ok1,ok2,ok,L,R,top;
scanf("%d",&T);
while(T--)
{
ok1=;//记录第一行是否有可行点
ok2=;//记录第二行是否有可行点
ok=;
scanf("%d%d",&n,&m);
for(i=; i<n; i++)
scanf("%s",Map[i]);
scanf("%d",&q);
for(i=; i<=q; i++)
scanf("%d%d",&a[i],&b[i]);
for(i=; i<m; i++)
{
if(Map[][i]=='')
ok1=;
if(Map[n-][i]=='')
ok2=;
}
if(ok1 && ok2)
ok=;
if(!ok)//若第一行或最后一行无可行点,直接输出0
{
printf("0\n");
continue;
}
ans=;
L=;
R=q;
memset(book,,sizeof(book));//记录第一行被剪去的点
while(R>L)//二分查找年份
{
top=;
int mid=L+(R-L)/;
for(i=; i<=mid; i++)//当前为mid年,更新地图被侵蚀的点
{
int x=a[i];
int y=b[i];
Map[x][y]='';
}
ok=;
for(i=; i<m; i++)
{
if(Map[][i]=='' && !book[i])
{
memset(vis,,sizeof(vis));
ok=BFS(,i);
if(ok)//当年图上下可连通
break;
else
{
Stack[++top]=i;//若该点无法到达最后一行,记录改点为可能要被剪去的点
}
}
} if(ok)
{
L=mid+;
ans=max(ans,mid);
for(j=; j<=top; j++)//剪枝
{
int num=Stack[j];
book[num]=;
}
top=;
}
else
{
R=mid;
} for(i=; i<=mid; i++)//还原地图
{
int x=a[i];
int y=b[i];
Map[x][y]='';
}
} ok=;
for(i=; i<=L; i++)
{
int x=a[i];
int y=b[i];
Map[x][y]='';
}
for(i=; i<m; i++)
{
if(Map[][i]=='' && !book[i])
{
memset(vis,,sizeof(vis));
ok=BFS(,i);
if(ok)
break;
else
{
Stack[++top]=i;
}
}
}
if(ok)
ans=L; if(ans == q)
ans=-;
else
ans++;
printf("%d\n",ans);
}
return ;
}

HDU 5652 India and China Origins 二分优化+BFS剪枝的更多相关文章

  1. HDU 5652 India and China Origins 二分+并查集

    India and China Origins 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5652 Description A long time ...

  2. (hdu)5652 India and China Origins 二分+dfs

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5652 Problem Description A long time ago there ...

  3. hdu 5652 India and China Origins 二分+bfs

    题目链接 给一个图, 由01组成, 1不能走. 给q个操作, 每个操作将一个点变为1, 问至少多少个操作之后, 图的上方和下方不联通. 二分操作, 然后bfs判联通就好了. #include < ...

  4. hdu 5652 India and China Origins 并查集+二分

    India and China Origins Time Limit: 2000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...

  5. 并查集(逆序处理):HDU 5652 India and China Origins

    India and China Origins Time Limit: 2000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...

  6. HDU 5652 India and China Origins(并查集)

    India and China Origins Time Limit: 2000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...

  7. hdu 5652 India and China Origins 并查集

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5652 题目大意:n*m的矩阵上,0为平原,1为山.q个询问,第i个询问给定坐标xi,yi,表示i年后这 ...

  8. hdu 5652 India and China Origins(二分+bfs || 并查集)BestCoder Round #77 (div.2)

    题意: 给一个n*m的矩阵作为地图,0为通路,1为阻碍.只能向上下左右四个方向走.每一年会在一个通路上长出一个阻碍,求第几年最上面一行与最下面一行会被隔开. 输入: 首行一个整数t,表示共有t组数据. ...

  9. hdu 5652 India and China Origins 并查集+逆序

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5652 题意:一张n*m个格子的点,0表示可走,1表示堵塞.每个节点都是四方向走.开始输入初始状态方格, ...

随机推荐

  1. GlusterFS缺点分析[转]

    原文:http://blog.sina.com.cn/s/blog_6b89db7a0101gbcy.html GlusterFS(GNU ClusterFile System)是一个开源的分布式文件 ...

  2. 设计模式 单例模式(Singleton) [ 转载 ]

    设计模式 单例模式(Singleton) [ 转载 ] 转载请注明出处:http://cantellow.iteye.com/blog/838473 前言 懒汉:调用时才创建对象 饿汉:类初始化时就创 ...

  3. Java Object 引用传递和值传递

    Java Object 引用传递和值传递 @author ixenos Java没有引用传递: 除了在将参数传递给方法(或函数)的时候是"值传递",传递对象引用的副本,在任何用&q ...

  4. 处理Properties文件中key包含空格的情况

    在这个互联网信息共享的时代,好处是一个问题的很多解决方案都可以从网络上得到,不好的一点就是很多人喜欢复制粘贴也不注明转载出处,不尊重别人的劳动成果,不假思索地把别人的原创复制到自己的博客然后发布,请大 ...

  5. CSS3 学习小结

    写样式时有时遇到浏览器兼容问题:-webkit-transition:chrome和safari-moz-transition:firefox-ms-transition:IE-o-transitio ...

  6. 关于java的上转型对象

    1. 定义 如果B类是A类的子类或间接子类,当用B类创建对象b并将这个对象b的引用赋给A类对象a时,如: A a;a = new B();ORA a;B b = new B();a = b; 则称A类 ...

  7. digitalocean更换机房教程

    使用本站优惠链接注册digitalocean账户,可获赠10美元digitalocean优惠码.新用户点击create,即可创建一台新的vps,10美元余额足够你使用一台512MB内存的vps长达两月 ...

  8. 不完善的css怦然心动,有待改进...

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  9. java的String类型为什么是final

    (转自:http://www.cnblogs.com/ikuman/archive/2013/08/27/3284410.html) 最佳答案: 主要是为了“效率” 和 “安全性” 的缘故.若 Str ...

  10. JavaScript获取浏览器信息的方法

    Window有navigator对象让我们得知浏览器的全部信息.我们可以利用一系列的API函数得知浏览器的信息. JavaScript代码如下: ? 1 2 3 4 5 6 7 8 9 10 11 1 ...