一道不难的题,可是挑了好久也没调好!因为最开始写的代码太复杂了,一大堆嵌套括号,其中有一个ny写成了nx一直没发现。后来用新定义变量取代了那些复杂的用函数、"."和方括号表达出来的量,尽管并没有让程序更快,却让我一眼便发现了错误,直接改正,教训是代码不要有太多中小括号嵌套,否则很难排错

原复杂代码:

#include <iostream>
#include <cstdio>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
using namespace std;
//1825
int N,M,b[305][305];
char m[305][305];
struct trs
{
int ax,ay,bx,by;
trs(){ax=ay=bx=by=0;}
};
struct pos
{
int x,y,t;
pos(){x=y=t=0;}
pos(int X,int Y,int T){x=X;y=Y;t=T;}
}npos;
map<char,trs> trsn;
string s;
const int kx[5]={0,0,0,1,-1},
ky[5]={0,1,-1,0,0};
int main()
{
cin>>N>>M;
for(int i=1;i<=N;i++)
{
cin>>s;
for(int j=0;j<M;j++)
{
m[i][j+1]=s[j];
if(s[j]=='@') npos.x=i,npos.y=j+1;
if('A'<=s[j]&&s[j]<='Z')
{
if(trsn[s[j]].ax==0)
{
trsn[s[j]].ax=i,trsn[s[j]].ay=j+1;
}
else
{
trsn[s[j]].bx=i,trsn[s[j]].by=j+1;
}
}
}
}
for(int i=1;i<=N;i++)m[i][0]=m[i][M+1]='#';
for(int i=1;i<=M;i++)m[0][i]=m[N+1][i]='#';
npos.t=0;//keyishan
b[npos.x][npos.y]=1;
queue<pos> q;
q.push(npos);
while(!q.empty())
{
npos=q.front();q.pop();
if(m[npos.x][npos.y]=='=')
{
cout<<npos.t<<endl;
return 0;
}
for(int i=1;i<=4;i++)
{
if(m[npos.x+kx[i]][npos.y+ky[i]]=='#')
continue;
if(b[npos.x+kx[i]][npos.y+ky[i]]==1) //判重
continue;
if(m[npos.x+kx[i]][npos.y+ky[i]]>='A'&&m[npos.x+kx[i]][npos.y+ky[i]]<='Z')
{ //cout<<m[npos.x+kx[i]][npos.y+ky[i]];
b[npos.x+kx[i]][npos.y+ky[i]]=1;
if(trsn[m[npos.x+kx[i]][npos.y+ky[i]]].ax==npos.x+kx[i]
&&trsn[m[npos.x+kx[i]][npos.y+ky[i]]].ay==npos.y+kx[i])
q.push(pos(trsn[m[npos.x+kx[i]][npos.y+ky[i]]].bx,trsn[m[npos.x+kx[i]][npos.y+ky[i]]].by,npos.t+1));
else
q.push(pos(trsn[m[npos.x+kx[i]][npos.y+ky[i]]].ax,trsn[m[npos.x+kx[i]][npos.y+ky[i]]].ay,npos.t+1));
}
else
{
b[npos.x+kx[i]][npos.y+ky[i]]=1;
q.push(pos(npos.x+kx[i],npos.y+ky[i],npos.t+1));
}
/*cout<<endl;cout<<endl;
for(int i=1;i<=N;i++)
{
for(int j=1;j<=M;j++)cout<<b[i][j];
cout<<endl;
}*/
}
}
cout<<-1<<endl;
return 0;
}

神清气爽的新代码

#include <iostream>
#include <cstdio>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
using namespace std;
//1825
int N,M,b[305][305];
char m[305][305];
struct trs
{
int ax,ay,bx,by;
trs(){ax=ay=bx=by=0;}
};
struct pos
{
int x,y,t;
pos(){x=y=t=0;}
pos(int X,int Y,int T){x=X;y=Y;t=T;}
}npos;
map<char,trs> trsn;
string s;
const int kx[5]={0,0,0,1,-1},
ky[5]={0,1,-1,0,0};
int main()
{
cin>>N>>M;
for(int i=1;i<=N;i++)
{
cin>>s;
for(int j=0;j<M;j++)
{
m[i][j+1]=s[j];
if(s[j]=='@') npos.x=i,npos.y=j+1;
if('A'<=s[j]&&s[j]<='Z')
{
if(trsn[s[j]].ax==0)
{
trsn[s[j]].ax=i,trsn[s[j]].ay=j+1;
}
else
{
trsn[s[j]].bx=i,trsn[s[j]].by=j+1;
}
}
}
}
for(int i=1;i<=N;i++)m[i][0]=m[i][M+1]='#';
for(int i=1;i<=M;i++)m[0][i]=m[N+1][i]='#';
npos.t=0;//keyishan
b[npos.x][npos.y]=1;
queue<pos> q;
q.push(npos);
while(!q.empty())
{
npos=q.front();q.pop();
if(m[npos.x][npos.y]=='=')
{
cout<<npos.t<<endl;
return 0;
}
for(int i=1;i<=4;i++)
{
int nx=npos.x+kx[i],ny=npos.y+ky[i];
if(m[nx][ny]=='#')
continue;
if(b[nx][ny]==1) //判重
continue;
if(m[nx][ny]>='A'&&m[nx][ny]<='Z')
{
b[nx][ny]=1;
if(trsn[m[nx][ny]].ax==nx&&trsn[m[nx][ny]].ay==ny)
q.push(pos(trsn[m[nx][ny]].bx,trsn[m[nx][ny]].by,npos.t+1));
else
q.push(pos(trsn[m[nx][ny]].ax,trsn[m[nx][ny]].ay,npos.t+1));
}
else
{
b[nx][ny]=1;
q.push(pos(nx,ny,npos.t+1));
}
/*cout<<endl;cout<<endl;
for(int i=1;i<=N;i++)
{
for(int j=1;j<=M;j++)cout<<b[i][j];
cout<<endl;
}*/
}
}
cout<<-1<<endl;
return 0;
}

但这个代码只有95分,有一个点RE了。

诡异的是,我下面这个代码AC了:

#include <iostream>
#include <cstdio>
#include<algorithm>
#include<string>
#include<map>
#include<queue>
using namespace std; int N,M,b[310][310];
char m[310][310];
struct trs
{
int ax,ay,bx,by;
trs(){ax=ay=bx=by=0;}
};
struct pos
{
int x,y,t;
pos(){x=y=t=0;}
pos(int X,int Y,int T){x=X;y=Y;t=T;}
}npos;
map<char,trs> trsn;
string s;
const int kx[5]={0,0,0,1,-1},
ky[5]={0,1,-1,0,0}; int main()
{
cin>>N>>M;
for(int i=1;i<=N;i++)
{
cin>>s;
for(int j=0;j<M;j++)
{
m[i][j+1]=s[j];
if(s[j]=='@') npos.x=i,npos.y=j+1;
if('A'<=s[j]&&s[j]<='Z')
{
if(trsn[s[j]].ax==0)
{
trsn[s[j]].ax=i,trsn[s[j]].ay=j+1;
}
else
{
trsn[s[j]].bx=i,trsn[s[j]].by=j+1;
}
}
}
}
b[npos.x][npos.y]=1;
queue<pos> q;
q.push(npos);
while(!q.empty())
{
npos=q.front();q.pop();
if(m[npos.x][npos.y]=='=')
{
cout<<npos.t<<endl;
return 0;
}
for(int i=1;i<=4;i++)
{
int nx=npos.x+kx[i],ny=npos.y+ky[i];
if(nx<1||nx>N||ny<1||ny>M||m[nx][ny]=='#'||b[nx][ny]==1)
continue;
if(m[nx][ny]>='A'&&m[nx][ny]<='Z')
{
b[nx][ny]=1;
if(trsn[m[nx][ny]].ax==nx&&trsn[m[nx][ny]].ay==ny)
q.push(pos(trsn[m[nx][ny]].bx,trsn[m[nx][ny]].by,npos.t+1));
else
q.push(pos(trsn[m[nx][ny]].ax,trsn[m[nx][ny]].ay,npos.t+1));
}
else
{
b[nx][ny]=1;
q.push(pos(nx,ny,npos.t+1));
}
}
}
cout<<-1<<endl;
return 0;
}

为什么说这个代码诡异呢,因为这代码本质上和上一个是一样的,上一个是把越界数据设置为墙,然后用不撞墙代码来确保不越界,后一个是直接确保不越界。凭什么后一个导致RE?一定要研究清楚。

另外,还有一个诡异的问题。当输入某组数据(一会我给出)时,理应输出75,洛谷的评测数据是75,我的程序也算出了75。当我自己用肉眼观察那组数据时,发现这个迷宫应该没有解呀应该走不出来呀,怎么会75步就走出来了呢。

数据是这样的:

########################################################################################################################################################################################################
=.B####.#.##....#..###.#.#.#######Y#.#.##.####K..I###....####.#####.####.#.#.########.#...#F#####.##..####......#.##.#######..##.#.#######.#..###.#F......P###..##..##..#.###..###.#.####M.#.###.##.####
####.######.D######..#.#####S.####P#...##.##.##########.##.##.####.##...#########.#.##...#..J.#..#.#.#..######.#N####.##.###.....L####.L..#..#EE#..#.#..###.####..#####..#...Q#####.#####K..#.##.####..#
#######.#.#..#.#...###..##I...#####.#####.####..##.#####.#####..#####.##..#..####.#######.....#..##.#####.#####..#...###.....#####.#..#...#.#...G#...###...##...####.#####....#.##########....#####...##
######.#.#..###..##.##.##.#########.####.#.#.#.###.#.#.###..R##.#.####.####.#.#..####..###########.###.##.#.Q###.#.##.##..####..#####.##B###..#..##..#####.###...##..########.####.#.#..###.##J.##..#..#
##X...#.##...###..########...#.#.##.###......#####.#####.#A####.##.#.##.#..###.##..#####....######..#...####..##.#H..#O...###.##..##.####.#.#.##N.#.####.########..####.##.##..###########...##X#..#..##
#####.###..###.###.#####....##.####.####.#.#..#.#..###.###..###.#.#####..###.###...###.#####.####.##.###...#.#..###.#############.##.##..###.#G##.##..######..###.###.#.####.####.###.###.#..##...##.###
###A..##..#####..#..#.###.##...#YC#.#O...##.#..........######.###..#.#.####.###..#######....##..#.###.#..#..#...##.##M..#.#..#...#.##.####.##.#S####.###.##..#.#######.######.#D######.#..#......###..##
######R..#.###.##.#.#.##.###..######.##..#.##..#####..Z###..#H.#.####.#.#.#.#ZC##...#...#.....###.#..###...#####.###..##.####..##.#.##..#####.##########.#.#..#.#...####.####...###...##...#..###.#...@#
########################################################################################################################################################################################################

这个迷宫我自己从出口倒着走,发现所有路都是死胡同,这就诡异了,我和洛谷的算法同时算出75步能走出,可我自己观察这个迷宫时却发现走不出来

P1825 诡异的题的更多相关文章

  1. 【BZOJ】【1011】【HNOI2008】遥远的行星

    神奇的思路题QAQ 玛雅看到这题我就醉了,什么玩意……5%的误差?果断膜拜@ydc神犇的题解: 就是因为不清楚如何应用那个答案误差不超过5%啦. 从没见过这么诡异的题一下就懵了,问到了方法之后都还半信 ...

  2. 题解-洛谷P1184 高手之在一起

    https://www.luogu.org/problemnew/show/P1184 (题目出处) 见到地名,自然就想到字符串了.可以从第一天开始,将她的位置与高手方便取得地方一一比较,(char字 ...

  3. 洛谷 P2664 树上游戏 解题报告

    P2664 树上游戏 题目描述 \(\text{lrb}\)有一棵树,树的每个节点有个颜色.给一个长度为\(n\)的颜色序列,定义\(s(i,j)\) 为 \(i\) 到 \(j\) 的颜色数量.以及 ...

  4. P2857 [USACO06FEB]稳定奶牛分配Steady Cow Assignment

    题目描述 Farmer John's N (1 <= N <= 1000) cows each reside in one of B (1 <= B <= 20) barns ...

  5. 51nod 1222 最小公倍数计数【莫比乌斯反演】

    参考:https://www.cnblogs.com/SilverNebula/p/7045199.html 所是反演其实反演作用不大,又是一道做起来感觉诡异的题 转成前缀和相减的形式 \[ \sum ...

  6. (诡异Floyd&amp;自环)MZ Training 2014 #15 E题(POJ 2240)

    你们见过这么诡异的FLOYD吗? 先上题. [Description] 货币的汇率存在差异.比如,如果1美元购买0.5英镑,1英镑买10法郎.而1法国法郎买0.21美元.然后,通过转换货币,一个聪明的 ...

  7. 套题T8&T9

    A - 8球胜负(eight) Time Limit:1000MS     Memory Limit:65535KB     64bit IO Format:%lld & %llu Submi ...

  8. 【翻译】Zakas解答Baranovskiy的JavaScript测验题

    原文:http://www.nczonline.net/blog/2010/01/26/answering-baranovskiys-javascript-quiz/ ---------------- ...

  9. linux诡异的半连接(SYN_RECV)队列长度

    linux诡异的半连接(SYN_RECV)队列长度(一) >>转载请注明来源:飘零的代码 piao2010 ’s blog,谢谢!^_^>>本文链接地址:linux诡异的半连接 ...

  10. A - 娜娜梦游仙境系列——诡异的钢琴

    A - 娜娜梦游仙境系列——诡异的钢琴 Time Limit: 2000/1000MS (Java/Others)    Memory Limit: 128000/64000KB (Java/Othe ...

随机推荐

  1. 【scikit-learn基础】--『预处理』之 标准化

    数据的预处理是数据分析,或者机器学习训练前的重要步骤.通过数据预处理,可以 提高数据质量,处理数据的缺失值.异常值和重复值等问题,增加数据的准确性和可靠性 整合不同数据,数据的来源和结构可能多种多样, ...

  2. 零基础 从 yolo8 入门计算机视觉超简单:物体识别、图像分类、轨迹追踪、姿势识别

    目录 安装 Ultralytics 训练 模型验证 预测 & 识别 导出 追踪 图像分割提取 分类 姿势识别 轨迹生成 Ultralytics YOLOv8 是备受好评的实时目标检测和图像分割 ...

  3. 如何给图数据库 NebulaGraph 新增一种数据类型,以 Binary 为例

    NebulaGraph 内核所自带的数据结构其实已经很丰富了,比如 List.Set.Map.Duration.DataSet 等等,但是我们平时在建表和数据写入的时候,可以用到的数据结构其实比较有限 ...

  4. flask蓝图(这玩意就是django的子应用)

    蓝图的概念类似django的子应用,作用就是分模块开发,有关联的都放在一起. 蓝图的创建步骤: 新建一个包(一个包就是一个模块.等同于一个子应用) 在包的__init__.py中创建蓝图对象 . 蓝图 ...

  5. 山海鲸Cesium:用更简单的方式升级视效

    CesiumJS作为绝大多数人都在用的开源地球可视化引擎,视觉效果并不拔尖,这让很多giser都想着有一天升级一下视效,从众多平庸的项目中脱颖而出.然而,对于一些使用Cesium的项目来说,要想达到C ...

  6. 【笔记】Ribbon负载均衡伪随机算法

    伪随机:思路 当一个下标(伪服务)连接被调用两次,第三次如果还是它,就让再随机一次 当重复随机到一台服务两次时判断第三次是否还是它 是的话 我们要进行 再次随机 也就是第三次 package top. ...

  7. Kiractf

    信息收集 主机发现和端口扫描只开放了80的web服务 ​​ ‍ WEB打点 访问首页有文件上传,肯定可以利用一波.language那个页面甚至文件包含都写脸上了. root@Lockly tmp/ki ...

  8. 华硕AX系列路由器选购,以及华硕WIFI6路由器智能设备家电无法互联的解决方法。

    家里昨天换了一整套wifi6路由器(华硕AX82U+XD4R),刚刚换上就发现原来的欧普智能灯和部分其他设备无法使用了,而小米等设备等都可以互联,智能家居绝大部分用的是2.4G的协议,所以说,问题出现 ...

  9. Spring 事务的实现原理

    在执行访问数据库相关的操作中,特别是针对数据的修改操作,由于对于数据的修改可能会出现异常,因此对于整个一组的数据修改实际上都不能算是生效的,在这种情况下,需要使用事务的 "回滚" ...

  10. vue强制横屏

    在app.vue中 <template> <div id="app"> <router-view /> </div> </te ...