题目链接:http://acm.swust.edu.cn/problem/0582/

Time limit(ms): 5000        Memory limit(kb): 65535
 
Description
西南科技大学人数众多,学生多了附近的网吧也多。 
很多同学都热衷于上网,虽然学校提供了开放机房,但由于各种原因导致大家去网吧的兴趣还高些。平时网吧的情况还好些,然而周末放假是绝好的时间,但是学校人多啊,一放学去网吧的人就开始狂奔,竞争之激烈,抢到机子的难度非常之大。往往在我们到达网吧之前都坐满了。 
学校到网吧的路是错综复杂的,以致于到一个自己想去的网吧都有非常多的路线可以选择,而路线的长度又不相同,这样就决定了要花费的时间,因此想要尽快到达,选择一条最佳的线路是很有必要的。 
为了简化问题,我们把学校与周边的网吧看做图中的顶点,学校与网吧,网吧与网吧之间的路线看做边,每个边都有一个权,表示我们走完这条路的时间,由于放学人流量大,如果反向走会有危险,因此这是一个有向图。 
我的的学校在S点,想要去的网吧在T点。你的任务就是选择一条最佳路线,使得从学校到目的地网吧的时间最短,你只需要输出最短到达时间即可。

 
Input
共有M+2 行数据 
第一行两个整数N,M,表示点数和边数。 
然后M行每行3 个正整数(u,v,t),表示有一条可由u 到v耗时为t的边。 
最后一行两个正整数S、T。 
1< N <=10000,1<= M <=100000

 
Output
只有一行,一个整数表示最短时间。如果S、T之间不存在通路则输 
出“No Solution!”(双引号不输出)。

 
Sample Input
4 4
1 2 3
2 4 10
1 3 5
3 4 5
1 4
Sample Output
10
 
解题思路:明显是求单源最短路径,时间不可能为负值吧,不存在负环,所以这里用SPFA(链接)可以轻松搞定Orz~~~
代码如下:
 #include <iostream>
#include <queue>
#include <vector>
#include <cstring>
using namespace std; #define maxn 10005
#define inf 0x3f3f3f3f struct node{
int v, w;
node(int x, int y) :v(x), w(y){};
node(){};
}; vector<node>mpt[maxn];
//ptr判断一个点的入队操作次数,判断负环
int vis[maxn], ptr[maxn], dis[maxn], t, n, m, u, v, w, s; int Spfa(int s){
queue<int>Q;
Q.push(s);
vis[s] = , dis[s] = , ptr[s] = ;
while (!Q.empty()){
int u = Q.front();
Q.pop();
vis[u] = ;
for (int i = ; i<mpt[u].size(); i++){
v = mpt[u][i].v;
if (dis[v]>dis[u] + mpt[u][i].w){
dis[v] = dis[u] + mpt[u][i].w;
if (!vis[v]){
vis[v] = ;
Q.push(v);
if (++ptr[v] > n) return ;
}
}
}
}
return ;
} int main(){
while (cin >> n >> m){
memset(vis, , sizeof(vis));
memset(dis, inf, sizeof(dis));
memset(ptr, , sizeof(ptr));
for (int i = ; i < m; i++){
cin >> u >> v >> w;
mpt[u].push_back(node(v, w));
}
cin >> s >> t;
if (Spfa(s))
cout << dis[t] << endl;
else
cout << "No Solution!\n";
}
return ;
}

[Swust OJ 582]--放学了,抢机子了(SPFA)的更多相关文章

  1. [Swust OJ 404]--最小代价树(动态规划)

    题目链接:http://acm.swust.edu.cn/problem/code/745255/ Time limit(ms): 1000 Memory limit(kb): 65535   Des ...

  2. [Swust OJ 649]--NBA Finals(dp,后台略(hen)坑)

    题目链接:http://acm.swust.edu.cn/problem/649/ Time limit(ms): 1000 Memory limit(kb): 65535 Consider two ...

  3. SWUST OJ NBA Finals(0649)

    NBA Finals(0649) Time limit(ms): 1000 Memory limit(kb): 65535 Submission: 404 Accepted: 128   Descri ...

  4. [Swust OJ 1023]--Escape(带点其他状态的BFS)

    解题思路:http://acm.swust.edu.cn/problem/1023/ Time limit(ms): 5000 Memory limit(kb): 65535     Descript ...

  5. [Swust OJ 1125]--又见GCD(数论,素数表存贮因子)

    题目链接:http://acm.swust.edu.cn/problem/1125/ Time limit(ms): 1000 Memory limit(kb): 65535   Descriptio ...

  6. [Swust OJ 1126]--神奇的矩阵(BFS,预处理,打表)

    题目链接:http://acm.swust.edu.cn/problem/1126/ Time limit(ms): 1000 Memory limit(kb): 65535 上一周里,患有XX症的哈 ...

  7. [Swust OJ 1026]--Egg pain's hzf

      题目链接:http://acm.swust.edu.cn/problem/1026/     Time limit(ms): 3000 Memory limit(kb): 65535   hzf ...

  8. [Swust OJ 1139]--Coin-row problem

    题目链接:  http://acm.swust.edu.cn/contest/0226/problem/1139/ There is a row of n coins whose values are ...

  9. [Swust OJ 385]--自动写诗

    题目链接:http://acm.swust.edu.cn/problem/0385/ Time limit(ms): 5000 Memory limit(kb): 65535    Descripti ...

随机推荐

  1. 练习一下linux中的list函数。

    所有的list函数见 include/linux/list.h 自己从 include/linux/list.h 拷贝了一些函数到自己的list.c中, 然后练习了一下. 没有别的目的,就是想熟练一下 ...

  2. [虚拟化/云][全栈demo] 为qemu增加一个PCI的watchdog外设(五)

    目的: 1. 了解PCI的基本知识,为完成watchdog的设备做准备. 准备知识: 简单的说,PCI 设备分3个空间. 配置空间,IO空间,内存地址空间. PCI设备厂家决定了外设是使用IO空间还是 ...

  3. [虚拟化/云][全栈demo] 为qemu增加一个PCI的watchdog外设(三)

    我们已经设计了一个基于qemu的watchdog了.下一步工作就是创建一个含有我们的watchdog的虚拟计算机器了. 准备工作: 1. 使用virt-manager或者virsh创建一个虚拟机器. ...

  4. SQL SERVER 2000/2005/2008数据库数据迁移到Oracle 10G细述

    最近参与的一个系统涉及到把SQL Server 2k的数据迁移到Oracle 10G这一非功能需求.特将涉及到相关步骤列举如下供大家参考: 环境及现有资源: 1.OS: Windows 7 Enter ...

  5. 达内TTS6.0课件oop_day03

  6. _视图控制对象生命周期-init、viewDidLoad、viewWillAppear、viewDidAppear、viewWillDisappear等的区别及用途

    iOS视图控制对象生命周期-init.viewDidLoad.viewWillAppear.viewDidAppear.viewWillDisappear.viewDidDisappear的区别及用途 ...

  7. 转载 LayoutInflater的inflate函数用法详解

    http://www.open-open.com/lib/view/open1328837587484.html LayoutInflater的inflate函数用法详解 LayoutInflater ...

  8. SQL 语句优化—— (一) 操作符优化

    1.IN 操作符 用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格.但是用IN的SQL性能总是比较低的,从Oracle执行的步骤来分析用IN的SQL与不用IN的SQL有以 ...

  9. BZOJ 2300: [HAOI2011]防线修建( 动态凸包 )

    离线然后倒着做就变成了支持加点的动态凸包...用平衡树维护上凸壳...时间复杂度O(NlogN) --------------------------------------------------- ...

  10. linux grep 指定字符串的正则表达式

    cat all_uuid_log | grep "[a-z0-9]\{32\}"