PAT (Advanced Level) Practice - 1111 Online Map(30 分)

简介: PAT (Advanced Level) Practice - 1111 Online Map(30 分)

题目链接:点击打开链接

题目大意:经典Dijkstra。

解题思路:略。


AC 代码

#include<bits/stdc++.h>#include<cmath>#define mem(a,b) memset(a,b,sizeof a)#define ssclr(ss) ss.clear(), ss.str("")#define INF 0x3f3f3f3f#define MOD 1000000007usingnamespacestd;
typedeflonglongll;
constintmaxn=520;
intn,m;
intvis[maxn], dis[maxn], fst[maxn], pre1[maxn], pre2[maxn], num[maxn];
intg[maxn][maxn], fast[maxn][maxn];
vector<int>path1,path2;
intdijkstra1(ints)
{
dis[s]=0, fst[s]=0;
while(1)
    {
intmi=INF; s=-1;
for(inti=0;i<n;i++)
if(!vis[i] &&dis[i]<mi) mi=dis[i], s=i;
if(s==-1) return0;
vis[s]=1;
for(inti=0;i<n;i++)
        {
if(!vis[i] &&mi+g[s][i]<dis[i])
            {
dis[i]=mi+g[s][i];
fst[i]=fst[s]+fast[s][i];
pre1[i]=s;
            }
elseif(!vis[i] &&mi+g[s][i]==dis[i] &&fst[s]+fast[s][i]<fst[i])
            {
fst[i]=fst[s]+fast[s][i];
pre1[i]=s;
            }
        }
    }
}
intdijkstra2(ints)
{
fst[s]=0;
while(1)
    {
intmi=INF; s=-1;
for(inti=0;i<n;i++)
if(!vis[i] &&fst[i]<mi) mi=fst[i], s=i;
if(s==-1) return0;
vis[s]=1;
for(inti=0;i<n;i++)
        {
if(!vis[i] &&mi+fast[s][i]<fst[i])
            {
fst[i]=mi+fast[s][i];
num[i]=num[s]+1;
pre2[i]=s;
            }
elseif(!vis[i] &&mi+fast[s][i]==fst[i] &&num[s]+1<num[i])
            {
num[i]=num[s]+1;
pre2[i]=s;
            }
        }
    }
}
intmain()
{
mem(g,INF), mem(fast,INF), mem(dis,INF), mem(pre1,-1), mem(pre2,-1), mem(num,0);
intu,v,t,l,f;
scanf("%d%d",&n,&m);
for(inti=0;i<m;i++)
    {
scanf("%d%d%d%d%d",&u,&v,&f,&l,&t);
if(f) g[u][v]=l, fast[u][v]=t;
elseg[v][u]=g[u][v]=l, fast[v][u]=fast[u][v]=t;
    }
scanf("%d%d",&u,&v);
mem(vis,0), mem(fst,INF);
dijkstra1(u);
mem(vis,0), mem(fst,INF);
dijkstra2(u);
inth=v;
while(h!=-1)
    {
path1.push_back(h);
h=pre1[h];
    }
h=v;
while(h!=-1)
    {
path2.push_back(h);
h=pre2[h];
    }
if(path1==path2)
    {
printf("Distance = %d; Time = %d: ",dis[v],fst[v]);
for(inti=path1.size()-1;i>=0;i--)
printf("%d%s",path1[i],i==0?"\n":" -> ");
    }
else    {
printf("Distance = %d: ",dis[v]);
for(inti=path1.size()-1;i>=0;i--)
printf("%d%s",path1[i],i==0?"\n":" -> ");
printf("Time = %d: ",fst[v]);
for(inti=path2.size()-1;i>=0;i--)
printf("%d%s",path2[i],i==0?"\n":" -> ");
    }
return0;
}
目录
相关文章
|
存储 测试技术
PAT (Advanced Level) Practice - 1131 Subway Map(30 分)
PAT (Advanced Level) Practice - 1131 Subway Map(30 分)
119 0
|
7月前
|
Dart
Dart之集合详解(List、Set、Map)
Dart之集合详解(List、Set、Map)
|
7月前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
88 3
|
4月前
|
Go 定位技术 索引
Go 语言Map(集合) | 19
Go 语言Map(集合) | 19
|
4月前
|
存储 前端开发 API
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
该文章详细介绍了ES6中Set和Map数据结构的特性和使用方法,并探讨了它们在前端开发中的具体应用,包括如何利用这些数据结构来解决常见的编程问题。
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
|
5月前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
5月前
|
Java
【Java集合类面试二十二】、Map和Set有什么区别?
该CSDN博客文章讨论了Map和Set的区别,但提供的内容摘要并未直接解释这两种集合类型的差异。通常,Map是一种键值对集合,提供通过键快速检索值的能力,而Set是一个不允许重复元素的集合。
|
5月前
|
算法 Java 索引
【Java集合类面试四】、 描述一下Map put的过程
这篇文章详细描述了HashMap中put操作的过程,包括首次扩容、计算索引、插入数据以及链表转红黑树和可能的再次扩容。
【Java集合类面试四】、 描述一下Map put的过程
|
5月前
|
存储
|
5月前
|
安全 Java
【Java集合类面试五】、 如何得到一个线程安全的Map?
如何得到一个线程安全的Map的方法包括:使用Collections工具类将Map包装为线程安全,使用java.util.concurrent包下的ConcurrentHashMap,以及不推荐使用性能较差的Hashtable。