图的遍历 | 1131地铁图: dfs复杂模拟题
这题在搞清楚思路绕过坑后,还是可以写的出通过sample data的代码的。但是不能AC,让我很气。
最后查清原因:还是对dfs本质理解的不够。
wa代码:
vis[s]=1;
dfs(s,e,0);
殊不知本题有多个查询数据。如果只调用一遍还可以蒙混过关,但是这样的错误必然导致wa
ac代码:
vis[s]=1;
dfs(s,e,0);
vis[s]=0;
参考柳诺博客修改的AC代码:
#include <stdio.h>
#include <memory.h>
#include <math.h>
#include <string>
#include <vector>
#include <set>
#include <stack>
#include <queue>
#include <algorithm>
#include <map> #define I scanf
#define OL puts
#define O printf
#define F(a,b,c) for(a=b;a<c;a++)
#define FF(a,b) for(a=0;a<b;a++)
#define FG(a,b) for(a=b-1;a>=0;a--)
#define LEN 10000
#define MAX 0x06FFFFFF
#define V vector<int> using namespace std; vector<int> g[LEN];
int line[LEN][LEN];
int vis[LEN];
vector<int> path;
vector<int> ans;
int min_d=MAX;
int min_ls=MAX; int N,M,K; int calc_ls(){
int cnt=-,preLine=;
for(int i=;i<path.size();i++){
if(line[path[i-]][path[i]]!=preLine) cnt++;
preLine=line[path[i-]][path[i]];
}
return cnt;
} void dfs(int s,int e,int d){
if(s==e){
int ls=calc_ls();
if(d<min_d || (d==min_d && ls<min_ls)){
min_d=d;
min_ls=ls;
ans=path;
}
return;
}
int i;
FF(i,g[s].size()){
int o=g[s][i];
if(!vis[o]){
vis[o]=;
path.push_back(o);
dfs(o,e,d+);
vis[o]=;
path.pop_back();
}
} } void printLine(){
int s=ans[];
int preL=;
int i;
F(i,,ans.size()){
if(line[ans[i-]][ans[i]]!=preL){
if(preL) printf("Take Line#%d from %04d to %04d.\n",preL,s,ans[i-]);
s=ans[i-];
preL=line[ans[i-]][ans[i]];
}
}
printf("Take Line#%d from %04d to %04d.\n",preL,s,ans[i-]);
} int main(){
// freopen("1131.txt","r",stdin);
int s,e,i,j;
I("%d",&N);
F(i,,N+){
int pre,p=-;
I("%d",&M);
while(M--){
pre=p;
I("%d",&p);
if(pre>=){
g[p].push_back(pre);
g[pre].push_back(p);
line[p][pre]=i;
line[pre][p]=i;
}
}
}
I("%d",&K);
while(K--){
min_d=MAX;
min_ls=MAX;
path.clear();
ans.clear();
I("%d%d",&s,&e);
path.push_back(s);
vis[s]=;
dfs(s,e,);
vis[s]=;
O("%d\n",min_d);
printLine();
}
return ;
}
在自己思路上修改的AC代码:(个人认为比柳诺的好理解)
#include <stdio.h>
#include <memory.h>
#include <math.h>
#include <string>
#include <vector>
#include <set>
#include <stack>
#include <queue>
#include <algorithm>
#include <map> #define I scanf
#define OL puts
#define O printf
#define F(a,b,c) for(a=b;a<c;a++)
#define FF(a,b) for(a=0;a<b;a++)
#define FG(a,b) for(a=b-1;a>=0;a--)
#define LEN 10000
#define MAX 0x06FFFFFF
#define V vector<int> using namespace std; vector<int> g[LEN];
int line[LEN][LEN];
int vis[LEN];
vector<int> path;
vector<int> ans;
int min_d=MAX;
int min_ls=MAX; int N,M,K; void dfs(int s,int e,int d,int l,int ls){
if(s==e){
if(d<min_d || (d==min_d && ls<min_ls)){
min_d=d;
min_ls=ls;
ans=path;
}
return;
}
int i;
FF(i,g[s].size()){
int o=g[s][i];
if(!vis[o]){
vis[o]=;
path.push_back(o);
int nl=line[s][o];
int nls=ls;
if(l==){ //初始结点
nls=;
}else{
if(nl!=l) nls++;
}
dfs(o,e,d+,nl,nls);
vis[o]=;
path.pop_back();
}
} } void printLine(){
int s=ans[];
int preL=line[s][ans[]];
int i;
F(i,,ans.size()){
if(line[ans[i-]][ans[i]]!=preL){
printf("Take Line#%d from %04d to %04d.\n",preL,s,ans[i-]);
s=ans[i-];
preL=line[ans[i-]][ans[i]];
}
}
printf("Take Line#%d from %04d to %04d.\n",preL,s,ans[i-]);
} int main(){
// freopen("1131.txt","r",stdin);
int s,e,i,j;
I("%d",&N);
F(i,,N+){
int pre,p=-;
I("%d",&M);
while(M--){
pre=p;
I("%d",&p);
if(pre>=){
g[p].push_back(pre);
g[pre].push_back(p);
line[p][pre]=i;
line[pre][p]=i;
}
}
}
I("%d",&K);
while(K--){
min_d=MAX;
min_ls=MAX;
path.clear();
ans.clear();
I("%d%d",&s,&e);
vis[s]=;
dfs(s,e,,,);
vis[s]=;
O("%d\n",ans.size());
ans.insert(ans.begin(),s);
printLine();
}
return ;
}
注意点:
① 38 39 行,对维护的最小距离和最小换乘次数进行更新,不要写错(我开始写成了d=min_d ,查了很久的错,蠢哭……)
② 99 100 行,将最小距离和最小换乘次数重新初始化为INF。
③ 106 行,牢记 dfs 结构
图的遍历 | 1131地铁图: dfs复杂模拟题的更多相关文章
- 图的遍历(bfs 和dfs)
BFS的思想: 从一个图的某一个顶点V0出发,首先访问和V0相邻的且未被访问过的顶点V1.V2.……Vn,然后依次访问与V1.V2……Vn相邻且未被访问的顶点.如此继续,找到所要找的顶点或者遍历完整个 ...
- 图的遍历 之 深搜dfs
DFS 遍历 深度优先搜索是一个递归过程,有回退过程. 对一个无向连通图,在访问图中某一起始顶点u 后,由u 出发,访问它的某一邻接顶点v1:再从v1 出发,访问与v1 邻接但还没有访问过的顶点v2: ...
- PAT Advanced 1034 Head of a Gang (30) [图的遍历,BFS,DFS,并查集]
题目 One way that the police finds the head of a gang is to check people's phone calls. If there is a ...
- PAT Advanced 1076 Forwards on Weibo (30) [图的遍历,BFS,DFS]
题目 Weibo is known as the Chinese version of Twitter. One user on Weibo may have many followers, and ...
- 洛谷P3916||图的遍历||反向建图||链式前向星||dfs
题目描述 给出 NN 个点, MM 条边的有向图,对于每个点 vv ,求 A(v)A(v) 表示从点 vv 出发,能到达的编号最大的点. 解题思路 看起来很简单的一道题, 但我依然调了一天,我还是太菜 ...
- Luogu P3916 图的遍历 【优雅的dfs】【内有待填坑】By cellur925
说明 • 对于60% 的数据, n,m在1e3内 • 对于100% 的数据, n,m在1e5内. 本弱弱上来就是一顿暴搜打,dfs n次,每次更新答案,复杂度为O(n*n),果然TLE,60分抱回家. ...
- 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)
图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...
- 图的遍历——DFS(矩形空间)
首先,这里的图不是指的我们一般所说的图结构,而是大小为M*N的矩形区域(也可以看成是一个矩阵).而关于矩形区域的遍历问题经常出现,如“寻找矩阵中的路径”.“找到矩形区域的某个特殊点”等等之类的题目,在 ...
- 图的遍历——DFS和BFS模板(一般的图)
关于图的遍历,通常有深度优先搜索(DFS)和广度优先搜索(BFS),本文结合一般的图结构(邻接矩阵和邻接表),给出两种遍历算法的模板 1.深度优先搜索(DFS) #include<iostrea ...
随机推荐
- mysql性能的检查和优化方法
这个命令可以看到当前正在执行的sql语句,它会告知执行的sql.数据库名.执行的状态.来自的客户端ip.所使用的帐号.运行时间等信息 mysql在遇到严重性能问题时,一般都有这么几种可能:1.索引没有 ...
- 转: 彻底理解 Spring 容器和应用上下文
本文由 简悦 SimpRead 转码, 原文地址 https://mp.weixin.qq.com/s/o11jVTJRsBi998WlgpfrOw 有了 Spring 之后,通过依赖注入的方式,我们 ...
- 2019-11-29-win7-无法启动-WPF-程序-D3Dcompiler_47.dll-丢失
原文:2019-11-29-win7-无法启动-WPF-程序-D3Dcompiler_47.dll-丢失 title author date CreateTime categories win7 无法 ...
- BAT: Windows批处理更改当前工作路径
最近项目上需要获取文件夹下所有文件信息,因为文件夹是在server上,所以想用批处理bat来获取该路径下所有文件信息,然后通过任务计划管理去每天自动运行bat去更新文件信息内容. 获取文件夹下所有文件 ...
- 字节输出流FileOutputStream
#字节流 字节输出流FileOutputStream 创建输出流对象 OutputStream 流对象是一个抽象类,不能实例化.所以,我们要找一个具体的子类 :FileOutputStream. 查看 ...
- Ubuntu 16.4系统下安装docker
本文将介绍在ubuntu16.04系统下安装和升级docker.docker-compose.docker-machine. docker:有两个版本:docker-ce(社区版)和docker-ee ...
- 2019 识装java面试笔试题 (含面试题解析)
本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.识装等公司offer,岗位是Java后端开发,因为发展原因最终选择去了识装,入职一年时间了,也成为了面试官,之 ...
- 8、如何将本地新创建的项目上传到gitHub(gitLab)上
Git 常用命令 1. cd 项目目录 2.git init //变成git仓库 3.git add . //将项目添加到本地仓库 4.git commit -m '备注' //将项目提交 ...
- 编写合格的C代码(1):通过编译选项将特定警告视为错误
目录 快速设定 向错误的执念开炮,向C编译器开炮 编译警告应当被忽略吗?warning不重要吗? 个人总结的应当视作error的warning 1. 函数没有声明就使用 2. 函数虽然有声明,但是声明 ...
- 为 Jupyter 添加目录
1.依次在 anaconda prompt 窗口中执行以下两句命令 pip install jupyter_contrib_nbextensions # 安装第三方包 jupyter contrib ...