找bug hhh
http://oj.acm.zstu.edu.cn/JudgeOnline/problem.php?id=4434
没有用队列,疯狂找不到bug,后来发现很简单的判断时==n和m了,本来心花怒放,测试数据也过了。然而,呜呼,许久不见的re;
好的,re,re,重新,重新!!
然而,不死心的在开更大一点,发现是WA。
那什么时候bfs用数组就行了呢。。
唔,下面那个标注里 mark不会冲突,如果到了这个点上,那他往哪里走的可能性都是一样的 不改变就重复了
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
using namespace std;
][]={{-,},{,-},{,},{,}};
][];
][],n,m,r,s;
int ans;
struct node
{
int x,y,step;
}v[];
bool pan(int x,int y)
{
||y<||x>=n||y>=m) return false;
return true;
}
void bfs()
{
v[r].x=;
v[r].y=;
v[r].step=;
ma[][]=;
r++;s=;
;
while(s<r)
{
;i<;i++)
{
];
];
)
{
&&y==m-)
{
ans=v[s].step+;
ma[x][y]=;
d=;
break;
}
else if(mp[x][y]=='.')
{
v[r].x=x;
v[r].y=y;
v[r].step=v[s].step+;
r++;
ma[x][y]=; //各种路里mark不会相冲突吗
}
}
}
if(d) break;
s++;
}
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
;i<n;i++)
scanf("%s",mp[i]);
memset(ma,,sizeof(ma));
r=;
ans=;
bfs();
printf("%d\n",ans);
}
;
}
RE,数组表队列
#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int>node; //pair!! first
][]={{-,},{,-},{,},{,}};
][];
][],n,m;
void bfs()
{
queue<node>q;
node now={,};
ma[][]=;
while(!q.empty()) q.pop(); //clear
q.push(now);
while(!q.empty())
{
now=q.front();
q.pop();
;i<;i++)
{
]; //pair 这里可以define
];
||!x||!y||x==n+||y==m+||mp[x][y]=='*')//这了的!x
continue;
ma[x][y]=ma[now.first][now.second]+; //太**了,用标记顺便当step,充分利用
if(x==n&&y==m)
{
printf("%d\n",ma[x][y]);
return;
}
q.push({x,y});
}
}
puts("-1"); //把不可能的结果放在这里,注意位置
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
;i<=n;i++)
scanf(); //指针,不从第一个位置开始读
memset(ma,,sizeof(ma));
bfs();
}
;
}
学长写,虽然好像不兼容过不了,但是太厉害了!!
#pragma GCC diagnostic error "-std=c++11"
#include<bits/stdc++.h>
using namespace std;
//typedef pair<int,int>node; //pair!! first
][]={{-,},{,-},{,},{,}};
][];
][],n,m;
struct node{
int x,y;
};
void bfs()
{
queue<node>q;
node now;
now.x=;
now.y=;
ma[][]=;
while(!q.empty()) q.pop(); //clear
q.push(now);
while(!q.empty())
{
now=q.front();
q.pop();
;i<;i++)
{
];
];
||!x||!y||x==n+||y==m+||mp[x][y]=='*')//这了的!x
continue;
ma[x][y]=ma[now.x][now.y]+; //太**了,用标记顺便当step,充分利用
if(x==n&&y==m)
{
printf();
return;
}
node no;
no.x=x;
no.y=y;
q.push(no);
}
}
puts("-1"); //把不可能的结果放在这里,注意位置
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
;i<=n;i++)
scanf(); //指针,不从第一个位置开始读
memset(ma,,sizeof(ma));
bfs();
}
;
}
pair不能用后 改成struct
找bug hhh的更多相关文章
- 海王星给你好看!FineUI v4.0公测版发布暨《你找BUG我送书》活动开始(活动已结束!)
<FineUI v4.0 你找BUG我送书>活动已结束,恭喜如下三位网友获得由 FineUI 作者亲自翻译的图书<jQuery实战 第二版>! 奋斗~ 吉吉﹑ purplebo ...
- 第二次作业:找Bug
引子 我真的想了一个小时,上哪里去找bug.我昨天还留意到一个bug,今天就不见了.灵光不断,我想起来了.我就要找大公司的产品的bug... 第一部分 调研, 评测 体验. <腾讯桌球>是 ...
- 附加题程序找bug
private: void Resize(int sz){ ){ return; } if(maxSize != sz){ T *arr = new T[sz]; if(arr == NULL){ r ...
- 在无法单步调试的情况下找Bug的技巧
比如说你有一个大的模块A,其组成部分有B,C,D这3个小的模块,现在A出了一个BUG,因为某种原因的限制你无法单步调试.怎么较快地定位BUG发生的根源? 这里记录一下刚才我在找BUG的时候采用的思路, ...
- 找BUG
找一找BUG 一段代码,实现一个pop,push,和getmin都是O(1)的方法. 最初源代码 伙伴代码如下,代码的地址可以通过这个访问: Ubuntu Pastebin https://paste ...
- 判断空间上三个点是否共线问题【找bug篇】
判断空间上三个点是否在同一直线上[找bug篇] 作者:Vashon 时间:20150601 发布时间:20150718 一.拿到问题,首先分析并理清思路. 判断三点是否在同一条直线上需满足以下几点 ...
- 找bug的过程
关于昨天程序出差我找bug的过程记录 昨天才程序 https://www.cnblogs.com/pythonywy/p/11006273.html ├── xxxx │ ├── src.py │ └ ...
- 如何正确的找BUG
什么是BUG 漏洞是在硬件.软件.协议的具体实现或系统安全策略上存在的缺陷,从而可以使攻击者能够在未授权的情况下访问或破坏系统.具体举例来说,比如在Intel Pentium芯片中存在的逻辑错误,在S ...
- 一起找bug
帮同学找的一个bug,错误代码如下: package dai_test; public class Test1 { public static void main(String[] args) { / ...
随机推荐
- System.TypeInitializationException: The type initializer for 'Oracle.DataAccess.Client.OracleConnection' threw an exception. ---> Oracle.DataAccess.Client.OracleException: 提供程序与此版本的 Oracle 客户机不兼容”
.net应用程序通过Oracle.DataAccess.dll访问64位的Oracle服务器,在连接时出现以下异常:“System.TypeInitializationException: The t ...
- Oracle 数据备份与恢复
前言 一:备份与恢复概述 二:RMAN 工具概述 1: RMAN 组件 1: RMAN命令执行器 [oracle@localhost ~]$ rman target system/nocatalog ...
- 修改Mysql5.7的root密码
Mysql5.7修改root密码 禁用root密码 1.修改 /etc/my.cnf,在 [mysqld] 小节下添加一行:skip-grant-tables=1 这一行配置让 mysqld 启动时不 ...
- 在前台根据传过来的XX级别的数字转XX的名字
需求描述:进入页面,展示列表,列表中有个XX级别的项,数据库中的级别使用1234来存放的,现在要转成对应的一级XX,二级XX,三级XX,四级XX. 吐槽一下:正常的做法应该是在后台,就把查出来的级别1 ...
- 【层次聚类】python scipy实现
层次聚类 原理 有一个讲得很清楚的博客:博客地址 主要用于:没有groundtruth,且不知道要分几类的情况 用scipy模块实现聚类 参考函数说明: pdist squareform linkag ...
- 【python】ftp连接,主被动,调试等级
示例代码如下: #!/usr/bin/env python # -*- coding: utf-8 -*- import os from ftplib import FTP def ftp_down( ...
- PDF怎么去除页眉页脚,PDF页眉页脚编辑方法
我们在使用文件的时候需要编辑页眉页脚的时候,这个时候我们应该怎么做呢,相信别的文件大家都知道怎么编辑了,PDF文件大家都知道吗,最开始接触这个文件的时候小编觉得很难,之后找到技巧之后也并没有很难,今天 ...
- cf1107d 映射关系
#include<bits/stdc++.h> using namespace std; ][]; int judge(int i){ ;j<=n;j++) ][j]); ; } i ...
- java源代码
//信1705-1 20173527 刘津鑫 package money; import java.io.IOException; import java.io.Serializable; impor ...
- 使用android-ndk官方ndkbuild例子
Why this blog 现在(2018年9月27日),Android Studio中新建ndk项目都使用cmake而不是Android.mk+Application.mk的方式.但老项目需要维护, ...