一道不难的题,可是挑了好久也没调好!因为最开始写的代码太复杂了,一大堆嵌套括号,其中有一个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. DC静态时序分析之时钟篇

    DC静态时序分析之时钟篇博主微信:flm13724054952,不懂的有疑惑的也可以加微信咨询,欢迎大家前来投稿,谢谢! 引言介绍在芯片设计或者FPGA设计里面,根据有无时钟,将电路设计分为时序逻辑电 ...

  2. Linux笔记02: Linux环境_2.2 Linux系统安装

    2.2 Linux系统 本文使用的Linux系统为CentOS 7.9.2009,读者可以根据自己的需要选择不同的版本. 2.2.1 CentOS版本 CentOS基本上是安装在i386.x86_64 ...

  3. 循环依赖导致编译或者服务启动报错问题:The dependencies of some of the beans in the application context form a cycle

    错误如图: 我的是服务器启动服务时报错: ***************************APPLICATION FAILED TO START************************* ...

  4. 开源 Serverless 框架 Laf 性能优化实践

    介绍 Laf 是一个完全开源的 Serverless 框架,Laf 的 Node.js 运行时容器 (以下简称为 Runtime) 是 Laf 的函数执行环境,依托于 Express.js 框架.采用 ...

  5. 年度盘点,四年的精华合集「GitHub 热点速览」

    今年是 GPT 年,无论是 GitHub 还是朋友圈还是技术平台,即便你不关心 GPT 的发展情况,同大模型.AI 相关的项目总能进入你的信息流.到这期为止,热度速览也连载了四年,从一开始习惯看 Gi ...

  6. 混合专家模型 (MoE) 详解

    随着 Mixtral 8x7B (announcement, model card) 的推出,一种称为混合专家模型 (Mixed Expert Models,简称 MoEs) 的 Transforme ...

  7. python自动化测试相关资料

     java神功: https://yuedu.baidu.com/ebook/10f4bf7530126edb6f1aff00bed5b9f3f80f7212   selenium书:https:// ...

  8. ASR项目实战-架构设计

    一般而言,业务诉求作为架构设计的输入. 需求清单 对于语音识别产品而言,需满足的需求,举例如下: 功能需求 文件转写. 长文件转写,时长大于60秒,小于X小时,X可以指定为5. 短文件转写,时长小于6 ...

  9. ElasticSearch之cat master API

    命令样例如下: curl -X GET "https://localhost:9200/_cat/master?v=true&pretty" --cacert $ES_HO ...

  10. Mysql索引失效的几种原因-mysql-suo-yin-shi-xiao-de-ji-zhong-yuan-yin

    title: Mysql索引失效的几种原因 date: 2021-07-15 17:13:59.019 updated: 2021-12-26 17:43:12.489 url: https://ww ...