明天就要考PAT,为了应付期末已经好久没有刷题了啊啊啊啊,今天开了一道最短路,状态不是很好

1.没有读清题目要求,或者说没有读完题目,明天一定要注意

2.vis初始化的时候从1初始化到n,应该从0开始,以后初始化就从0到n即可

题目大意:给一张地图,两个结点中既有距离也有时间,有的单行有的双向,要求根据地图推荐两条路线:一条是最快到达路线,一条是最短距离的路线。

第一行给出两个整数N和M,表示地图中地点的个数和路径的条数。接下来的M行每一行给出:道路结点编号V1 道路结点编号V2 是否单行线 道路长度 所需时间

要求第一行输出最快到达时间Time和路径,第二行输出最短距离Distance和路径

就用两次dij+dfs即可,好嘛,今晚dfs也不用练了.最好明天出一道这道题

#include <iostream>
#include<bits/stdc++.h>
#define each(a,b,c) for(int a=b;a<=c;a++)
#define de(x) cout<<#x<<" "<<(x)<<endl
using namespace std; const int maxn=500+5;
const int inf=0x3f3f3f3f; int T[maxn][maxn];
int dis1[maxn];
int dis2[maxn];
bool vis[maxn];
int n,m,from,to;
vector<int>pre1[maxn],pre2[maxn];
/// vis =0 从0开始
struct edge
{
int v;
int length;
int time;
edge(int v,int length,int time):v(v),length(length),time(time){}
};
vector<edge>G[maxn];
struct node
{
int v;
int len;
node(int v=0,int len=0):v(v),len(len){}
bool operator<(const node&r)const
{
return len>r.len;
} };
void dijkstra1(int start,int n)
{
for(int i=0;i<=n;i++)
{
vis[i]=false;
dis1[i]=inf;
}
dis1[start]=0;
priority_queue<node>Q;
Q.push(node(start,0));
node temp;
while(!Q.empty())
{
temp=Q.top();
Q.pop();
int u=temp.v;
if(vis[u])continue;
vis[u]=true;
for(int i=0;i<G[u].size();i++)
{
int v=G[u][i].v;
int len=G[u][i].length;
if(!vis[v]&&dis1[v]>dis1[u]+len)
{
dis1[v]=dis1[u]+len;
pre1[v].clear();
pre1[v].push_back(u);
Q.push(node(v,dis1[v]));
}
else if(!vis[v]&&dis1[v]==dis1[u]+len)
{
pre1[v].push_back(u);
}
}
}
}
void dijkstra2(int start,int n)
{
for(int i=0;i<=n;i++)
{
vis[i]=false;
dis2[i]=inf;
}
dis2[start]=0;
priority_queue<node>Q;
while(!Q.empty())Q.pop();
Q.push(node(start,0)); node temp;
while(!Q.empty())
{
temp=Q.top();
Q.pop();
int u=temp.v;
if(vis[u])continue;
vis[u]=true;
for(int i=0;i<G[u].size();i++)
{
int v=G[u][i].v;
int len=G[u][i].time;
if(!vis[v]&&dis2[v]>dis2[u]+len)
{
dis2[v]=dis2[u]+len;
pre2[v].clear();
pre2[v].push_back(u);
Q.push(node(v,dis2[v]));
}
else if(!vis[v]&&dis2[v]==dis2[u]+len)
{
pre2[v].push_back(u);
}
}
}
}
vector<int>path;
vector<int>ans_path;
vector<int>ans_path2;
int min_time=inf;
void dfs1(int v)
{
path.push_back(v);
if(v==from)
{
int temp=0;
for(int i=0;i<path.size()-1;i++)
{
temp+=T[path[i+1]][path[i]];
}
if(temp<min_time)
{
min_time=temp;///忘记更新最小值了\吐血
ans_path=path;
}
path.pop_back();
return ;
}
for(int i=0;i<pre1[v].size();i++)
{
dfs1(pre1[v][i]);
}
path.pop_back(); }
int max_n=maxn;
void dfs2(int v)
{
path.push_back(v);
if(v==from)
{
if(path.size()<max_n)
{
max_n=path.size();
ans_path2=path;
}
path.pop_back();
return;
}
for(int i=0;i<pre2[v].size();i++)
{
dfs2(pre2[v][i]);
}
path.pop_back();
} /*
V1 V2 one-way length time
10 15
0 1 0 1 1
8 0 0 1 1
4 8 1 1 1
3 4 0 3 2
3 9 1 4 1
0 6 0 1 1
7 5 1 2 1
8 5 1 2 1
2 3 0 2 2
2 1 1 1 1
1 3 0 3 1
1 4 0 1 1
9 7 1 3 1
5 1 0 5 2
6 5 1 1 2
3 5
*/
int main()
{
cin>>n>>m;
int v1,v2,flag,len,time;
each(i,1,m)
{
cin>>v1>>v2>>flag>>len>>time;
if(flag==1)
{
G[v1].push_back(edge(v2,len,time));
T[v1][v2]=T[v2][v1]=time;
}
else
{
G[v1].push_back(edge(v2,len,time));
G[v2].push_back(edge(v1,len,time));
T[v1][v2]=T[v2][v1]=time;
}
}
cin>>from>>to;
dijkstra1(from,n);
dijkstra2(from,n);
//de(dis1[to]);
//de(dis2[to]);
dfs1(to);
dfs2(to);
printf("Distance = %d", dis1[to]);
if(ans_path == ans_path2) {
printf("; Time = %d: ", dis2[to]);
} else {
printf(": ");
for(int i = ans_path.size() - 1; i >= 0; i--) {
printf("%d", ans_path[i]);
if(i != 0) printf(" -> ");
}
printf("\nTime = %d: ", dis2[to]);
}
for(int i = ans_path2.size() - 1; i >= 0; i--) {
printf("%d", ans_path2[i]);
if(i != 0) printf(" -> ");
}
/*
Distance = 6: 3 -> 4 -> 8 -> 5
Time = 3: 3 -> 1 -> 5
*/
}

PAT-1111 Online Map (30分) 最短路+dfs的更多相关文章

  1. 【PAT甲级】1111 Online Map (30分)(dijkstra+路径记录)

    题意: 输入两个正整数N和M(N<=500,M<=N^2),分别代表点数和边数.接着输入M行每行包括一条边的两个结点(0~N-1),这条路的长度和通过这条路所需要的时间.接着输入两个整数表 ...

  2. PAT-1030 Travel Plan (30 分) 最短路最小边权 堆优化dijkstra+DFS

    PAT 1030 最短路最小边权 堆优化dijkstra+DFS 1030 Travel Plan (30 分) A traveler's map gives the distances betwee ...

  3. PAT 1111 Online Map[Dijkstra][dfs]

    1111 Online Map(30 分) Input our current position and a destination, an online map can recommend seve ...

  4. PAT 1004 Counting Leaves (30分)

    1004 Counting Leaves (30分) A family hierarchy is usually presented by a pedigree tree. Your job is t ...

  5. [PAT] 1147 Heaps(30 分)

    1147 Heaps(30 分) In computer science, a heap is a specialized tree-based data structure that satisfi ...

  6. PAT 甲级 1147 Heaps (30 分) (层序遍历,如何建树,后序输出,还有更简单的方法~)

    1147 Heaps (30 分)   In computer science, a heap is a specialized tree-based data structure that sati ...

  7. PAT 甲级1057 Stack (30 分)(不会,树状数组+二分)*****

    1057 Stack (30 分)   Stack is one of the most fundamental data structures, which is based on the prin ...

  8. PAT 甲级 1018 Public Bike Management (30 分)(dijstra+dfs,dfs记录路径,做了两天)

    1018 Public Bike Management (30 分)   There is a public bike service in Hangzhou City which provides ...

  9. PTA 1004 Counting Leaves (30)(30 分)(dfs或者bfs)

    1004 Counting Leaves (30)(30 分) A family hierarchy is usually presented by a pedigree tree. Your job ...

随机推荐

  1. NAXSI means Nginx Anti XSS & SQL Injection. NAXSI is an open-source, high performance, low rules maintenance WAF for NGINX

    nbs-system/naxsi: NAXSI is an open-source, high performance, low rules maintenance WAF for NGINXhttp ...

  2. Spring cloud微服务安全实战-3-10API安全机制之授权

    说一下最后一个模块,授权.用来做访问控制,控制哪个用户能干什么.哪个用户不能干什么? 遵循最小的授权原则,一个用户只给他必须要的那些权限. 1.你的请求是不是需要权限认证, 有一些请求是根本不需要权限 ...

  3. Spring cloud微服务安全实战-3-9API安全机制之审计日志

    首先说一下审计日志的处理.审计日志处理的位置,应该是在认证之后,授权之前.因为只有你在认证之后,你才能知道这个请求到底是谁发出来的,谁在做这个事情.在这个授权之前,这样的话那些被拒绝掉的请求.在响应的 ...

  4. python中异常处理之esle,except,else

    异常是指程序中的例外,违例情况.异常机制是指程序出现错误后,程序的处理方法.当出现错误后,程序的执行流程发生改变,程序的控制权转移到异常处理. python中使用try...except语句捕获异常, ...

  5. JAVA8中接口的一些新用法(springboot环境)

    @Configuration public interface IAbstractConvertStrategy { CacheService getCacheService(); default b ...

  6. SQL Delta实用案例介绍,很好的东西,帮了我不少忙

    SQL Delta实用案例介绍 概述 本篇文章主要介绍SQL DELTA的简单使用.为了能够更加明了的说明其功能,本文将通过实际项目中的案例加以介绍. 主要容 Ÿ   SQL DELTA 简介 Ÿ   ...

  7. MYSQL 递归操作

    MYSQL 递归? ===================== 表: t_node node_id int node_name varchar2(45) parent_id int       级, ...

  8. 常见问题:MySQL/事务隔离

    数据库并行产生的问题 A事务撤销时,将B事务更改的数据撤销. A事务提交时,将B事务更改的同行数据覆盖. 脏读:A事务读取到了B事务未提交的数据. 不可重复读:A事务中同查询语句不幂等,读到已更新数据 ...

  9. 【VS开发】从sockaddr中取得客户端或者数据源的Ip地址和端口号

    在socket编程中,服务器端accept()等待一个客户端的连接,当连接成功后,accept拷贝客户端的地址信息到sin_addr里面,我们如何从sin_addr取得此客户端的Ip地址和端口号呢? ...

  10. 修正线性单元(Rectified linear unit,ReLU)

    修正线性单元(Rectified linear unit,ReLU) Rectified linear unit 在神经网络中,常用到的激活函数有sigmoid函数f(x)=11+exp(−x).双曲 ...