点开有惊喜

其实是题面

这D1T1给的很有面子! 我居然做的来!

左上角走到右上角

然后n<=1000

所以果断放弃DFS,选择BFS

思路还是一样的BFS

证明:

走到一个点的时间越早越好(因为时间越晚能走到的点越少,路障多了)

所以用BFS,走过的点不用再次走,用 vis数组记录已经是否遍历过

然后为了防止跑出棋盘去(B君看到了棋盘外美铝?!)

我们就给棋盘加一个 '1'的边框,这样就不会出去

然后还要记录一个时间txy,可以用一个结构体

构造用

struct node{

​ int x,y,t;

​ node(int a,int b,int c):x(a),y(b),t(c) { }

​ node(){}

};

node(x,y,t)//直接构造

但是本菜还是比较喜欢用两个queue

一个存pair(x,t),一个存y

贴上:

#include<bits/stdc++.h>
#define INF 0x7f7f7f7f
using namespace std;
int Cx[4]={1,0,0,-1};//四个方向,八个方向也一样
int Cy[4]={0,1,-1,0};//在下有强迫症,所以用两个数组
int n,T;
int x,y;
int b[1010][1010];
bool vis[1010][1010];
int read()
{
int s=0;
char c=getchar();
while(!isdigit(c))
c=getchar();
while(isdigit(c))
{
s=(s<<1)+(s<<3)+c-'0';
c=getchar();
}
return s;
}
bool BFS()
{
int i,t;
int Tx,Ty;
queue<pair<int,int> >px;
queue<int>py;
while(!py.empty())
px.pop(),py.pop();
px.push(make_pair(1,1));
py.push(1);
vis[1][1]=1;
while(!px.empty())
{
x=px.front().first;
t=px.front().second;px.pop();
y=py.front();py.pop();
if(x==n&&y==n)//有了这句就不用特判n=1的情况了
return 1;
for(i=0;i<4;i++)
{
Tx=x+Cx[i];
Ty=y+Cy[i];
if(!vis[Tx][Ty]&&t<=b[Tx][Ty])
{
vis[Tx][Ty]=1;
px.push(make_pair(Tx,t+1));
py.push(Ty);
}
}
}
return 0;
}
int main()
{
int i;
T=read();
while(T--)
{
n=read();
memset(vis,0,sizeof(vis));
memset(b,INF,sizeof(b));//一开始赋无穷大比较方便
for(i=1;i<=n;i++)//裱框
vis[i][0]=vis[0][i]=vis[n+1][i]=vis[i][n+1]=1;
for(i=1;i<=2*n-2;i++)
{
x=read();y=read();
b[x][y]=i;
}
if(BFS())//此处纪念ydk大佬把"Yes"打成"YES",本蒟瑟瑟发抖
printf("Yes\n");
else
printf("No\n");
}
return 0;
}

「Luogu P3395」路障 解题报告的更多相关文章

  1. 「AHOI / HNOI2018」转盘 解题报告

    「AHOI / HNOI2018」转盘 可能是我语文水平不太行... 首先可以猜到一些事实,这个策略一定可以被一个式子表示出来,不然带修修改个锤子. 然后我们发现,可以枚举起点,然后直接往前走,如果要 ...

  2. 「CF670C」Cinema 解题报告

    题面 传送门 思路: 离散化.hash 对于这样一个明显的统计排序的题目,当然轻而易举啦~ 但是!看!语言的编号 a数组和 b数组的值最大在\(10^9\)的级别,所以开个数组来存---That's ...

  3. 「Luogu P3866」[TJOI2009]战争游戏 解题报告

    题面 好难表述啊~ 在n*m的矩阵上,有一些大兵(为0),一些空地(一个正整数),障碍物(-1),现在摧毁一些空地,使所有大兵不能走出矩阵去(代价为表示空地的整数),求最小代价 思路: 网络流最小割 ...

  4. 「Luogu P2201」数列编辑器 解题报告

    数列编辑器,在线IDE 本期的主题是洛谷的在线IDE 小学生?!小学生虐我

  5. 「Luogu P2015」二叉苹果树 解题报告

    题面 一个二叉树,边数为n\((2<n\le 100)\),每条边有一个权值,求剪枝后剩下p\((1<p<n)\)条边,使p条边的权值和最大 还看不懂?-- 2 5 input:5 ...

  6. 「Luogu P2508」[HAOI2008]圆上的整点 解题报告

    题面 给定圆的半径,求圆上整点数 这是一道很Nice的数学题!超爱!好吧,由于这道题,我去Study了一下复数(complex number)复杂的数 真棒!!! 有兴趣的戳这里!!!\(\huge ...

  7. 「Luogu P2278」[HNOI2003]操作系统 解题报告

    题面 一道模拟题,模拟CPU的处理过程?!省选模拟题 思路: 模拟退火大法+优先队列乱搞 要注意的点 1.空闲时,CPU要处理进程 2.当队列中没有进程时,要先进行判断,然后访问 3.当优先级高的进程 ...

  8. 「Luogu P1210」回文检测 解题报告

    题面 这是一道诡异的黄题 居然让你求一串吧啦吧啦的东西中 字母(大小写)最长的回文串的长度,还要输出完整的串 吐血 思路: 保持淡定,我们啥都不会,就会Manacher,那就用Manacher大法! ...

  9. 「Luogu P4987」回文项链 解题报告

    题面 求环中的长度为k(k为奇数)且回文中心不同的回文串个数 思路: 刚学manacher算法,就送上一道模板题,此题注重对manacher算法的理解 Manacher,但是不用插入其他符号,因为k是 ...

随机推荐

  1. @codeforces - 590E@ Birthday

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定 n 个互不相同的只包含 'a', 'b' 的字符串. 请选 ...

  2. @loj - 2288@「THUWC 2017」大葱的神力

    目录 @description@ @solution@ @data - 1@ @data - 2@ @data - 3@ @data - 4@ @data - 5@ @data - 6@ @data ...

  3. 解决pip is configured with locations that require TLS/SSL问题

    python3.7安装, 解决pip is configured with locations that require TLS/SSL问题1.安装相关依赖 yum install gcc libff ...

  4. hdu 5723 Abandoned country(2016多校第一场) (最小生成树+期望)

    Abandoned country Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others ...

  5. phpstorm鼠标显示问题

    https://segmentfault.com/q/1010000004319802 使用phpstorm,不知道碰到了什么键,鼠标变成了一个字符那么宽的灰色色块,原来是一根很细的竖线,怎么弄?没法 ...

  6. SuperSocket通过证书文件启用 TLS/SSL

    你需要通过下面的步骤修改配置文件来使用你准备好的证书文件: 在server节点设置security属性: 在server节点下增加certificate子节点: 最后配置应该像这样: <serv ...

  7. Python--day67--Django的路由系统

    原文:https://www.cnblogs.com/liwenzhou/articles/8271147.html Django的路由系统 Django 1.11版本 URLConf官方文档 URL ...

  8. Linux创建用户、设置密码、修改用户、删除用户命令

    与大家分享下Linux系统中创建用户.设置密码.修改用户.删除用户的命令,希望对你有所帮助. useradd testuser  创建用户testuserpasswd testuser  给已创建的用 ...

  9. 【u221】分数

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] 高考分数刚刚公布.共有n人参加考试,为了便于填报志愿,教育部把所有考生的成绩平均分为m档.保证n是m的 ...

  10. UVA 1343 - The Rotation Game-[IDA*迭代加深搜索]

    解题思路: 这是紫书上的一道题,一开始笔者按照书上的思路采用状态空间搜索,想了很多办法优化可是仍然超时,时间消耗大的原因是主要是: 1)状态转移代价很大,一次需要向八个方向寻找: 2)哈希表更新频繁: ...