hdu 1874 畅通工程(spfa 邻接矩阵 邻接表)
题目链接
畅通工程,可以用dijkstra算法实现。
听说spfa很好用,来水一发
邻接矩阵实现:
#include <stdio.h>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <deque>
#include <iomanip>
#include <iostream>
#include <list>
#include <map>
#include <queue>
#include <set>
#include <utility>
#include <vector>
#define mem(arr, num) memset(arr, 0, sizeof(arr))
#define _for(i, a, b) for (int i = a; i <= b; i++)
#define __for(i, a, b) for (int i = a; i >= b; i--)
#define IO \
ios::sync_with_stdio(false); \
cin.tie(); \
cout.tie();
using namespace std;
typedef long long ll;
const ll inf = 0x3f3f3f3f;
;
const ll mod = 1000000007LL;
+ ;
int mp[N][N], mp1[N][N];
int dis[N], vis[N];
int V, E;
void spfa(int start) {
; i <= V; i++) dis[i] = inf;
dis[start] = ;
vis[start] = ;
queue<int> q;
q.push(start);
while (!q.empty()) {
int v = q.front();
q.pop();
vis[v] = ;
; i <= mp1[v][]; i++) {
if (dis[mp1[v][i]] > dis[v] + mp[v][mp1[v][i]]) {
dis[mp1[v][i]] = dis[v] + mp[v][mp1[v][i]];
) q.push(mp1[v][i]), vis[mp1[v][i]] = ;
}
}
}
}
int main() {
int s, e, value;
while (cin >> V >> E) {
mem(mp,); mem(mp1,); mem(vis,);
_for(i, , E) {
cin >> s >> e >> value;
&& mp[s][e] < value) continue;
mp1[s][]++;
mp1[s][mp1[s][]] = e;
mp[s][e] = value; //记录mp度并且记录每个度的点的下标。
mp1[e][]++;
mp1[e][mp1[e][]] = s;
mp[e][s] = value;
}
int start, _end;
cin >> start >> _end;
spfa(start);
if (dis[_end] < inf)
cout << dis[_end] << endl;
else
cout << "-1" << endl;
}
;
}
邻接表实现:
#include <stdio.h>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <deque>
#include <iomanip>
#include <iostream>
#include <list>
#include <map>
#include <queue>
#include <set>
#include <utility>
#include <vector>
#define mem(arr, num) memset(arr, 0, sizeof(arr))
#define _for(i, a, b) for (int i = a; i <= b; i++)
#define __for(i, a, b) for (int i = a; i >= b; i--)
#define IO \
ios::sync_with_stdio(false); \
cin.tie(); \
cout.tie();
using namespace std;
typedef long long ll;
const ll inf = 0x3f3f3f3f;
;
const ll mod = 1000000007LL;
+ ;
<< ;
int mp[N][N], mp1[N][N];
int dis[N], vis[N];
int V, E;
int first[N];
;
struct edge {
int point, next, value;
} e[MAXN];
void add(int u, int v, int w) {
e[num].point = v;
e[num].next = first[u];
e[num].value = w;
first[u] = num++;
}
void spfa(int start) {
; i <= V; i++) dis[i] = inf;
dis[start] = ;
vis[start] = ;
queue<int> q;
q.push(start);
while (!q.empty()) {
int v = q.front();
q.pop();
vis[v] = ;
; tmp = e[tmp].next) {
if (dis[e[tmp].point] > dis[v] + e[tmp].value) {
dis[e[tmp].point] = dis[v] + e[tmp].value;
, q.push(e[tmp].point);
}
}
}
}
int main() {
int s, e, value;
while (cin >> V >> E) {
num = ;
mem(vis, );
int u, v, w;
_for(i, , V) { first[i] = -; }
_for(i, , E) {
cin >> u >> v >> w;
add(u, v, w);
add(v, u, w);
}
int start, _end;
cin >> start >> _end;
spfa(start);
if (dis[_end] < inf)
cout << dis[_end] << endl;
else
cout << "-1" << endl;
}
;
}
vector存储:
#include <stdio.h>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <deque>
#include <iomanip>
#include <iostream>
#include <list>
#include <map>
#include <queue>
#include <set>
#include <utility>
#include <vector>
#define mem(arr, num) memset(arr, 0, sizeof(arr))
#define _for(i, a, b) for (int i = a; i <= b; i++)
#define __for(i, a, b) for (int i = a; i >= b; i--)
#define IO \
ios::sync_with_stdio(false); \
cin.tie(); \
cout.tie();
using namespace std;
typedef long long ll;
const ll INFL = 0x3f3f3f3f3f3f3f3f;
const int INF = 0x3f3f3f3f;
;
const ll mod = 1000000007LL;
+ ;
<< ;
int dis[N], vis[N];
int V, E;
;
struct edge{
int point, value;
edge() {}
edge(int _p,int _v) {point = _p, value = _v;}
};
vector <edge> e[N];
void spfa(int st) {
; i <= V; i++) dis[i] = INF;
dis[st] = ;
vis[st] = ;
queue<int> q;
q.push(st);
while (!q.empty()) {
int v = q.front();
q.pop();
vis[v] = ;
vector <edge> :: iterator itor = e[v].begin();
for( ; itor != e[v].end(); itor++) {
if(dis[(*itor).point] > dis[v] + (*itor).value) {
dis[(*itor).point] = dis[v] + (*itor).value;
, q.push((*itor).point);
}
}
/*for(int i = 0; i < e[v].size(); i++) {
if(dis[e[v][i].point] > dis[v] + e[v][i].value) {
dis[e[v][i].point] = dis[v] + e[v][i].value;
if(!vis[e[v][i].point]) vis[e[v][i].point] = 1, q.push(e[v][i].point);
}
}*/
}
}
int main() {
while (~scanf("%d%d",&V,&E)) {
num = ;
mem(vis, );
int u, v, w;
_for(i, , V) { e[i].clear(); }
_for(i, , E) {
scanf("%d%d%d",&u,&v,&w);
e[u].push_back(edge(v,w));
e[v].push_back(edge(u,w));
}
int st, ed;
cin >> st >> ed;
spfa(st);
if (dis[ed] < INF)
cout << dis[ed] << endl;
else
cout << "-1" << endl;
}
;
}
hdu 1874 畅通工程(spfa 邻接矩阵 邻接表)的更多相关文章
- HDU 1874 畅通工程续-- Dijkstra算法详解 单源点最短路问题
参考 此题Dijkstra算法,一次AC.这个算法时间复杂度O(n2)附上该算法的演示图(来自维基百科): 附上: 迪科斯彻算法分解(优酷) problem link -> HDU 1874 ...
- ACM: HDU 1874 畅通工程续-Dijkstra算法
HDU 1874 畅通工程续 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Desc ...
- hdu 1874 畅通工程续
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过 ...
- HDU 1874畅通工程续(迪杰斯特拉算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Time Limit: 3000/1000 MS (Java/Others) ...
- HDU 1874 畅通工程续(最短路/spfa Dijkstra 邻接矩阵+邻接表)
题目链接: 传送门 畅通工程续 Time Limit: 1000MS Memory Limit: 65536K Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路. ...
- HDU 1874 畅通工程续 SPFA || dijkstra||floyd
http://acm.hdu.edu.cn/showproblem.php?pid=1874 题目大意: 给你一些点,让你求S到T的最短路径. 我只是来练习一下SPFA的 dijkstra+邻接矩阵 ...
- HDU——1874畅通工程续(邻接矩阵弗洛伊德)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- hdu 1874 畅通工程续(迪杰斯特拉优先队列,floyd,spfa)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- HDU——1874畅通工程续(Dijkstra与SPFA)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submiss ...
随机推荐
- ssm项目,web容器无法初始化项目
在web.xml中配置加载spring时,发现项目无法运行:而去掉spring的配置时,项目可以被初始化. 此时应考虑到spring的配置文件中存在错误,以至于web容器无法对项目成功初始化,在web ...
- [实战篇入门]02-POI简单创建Excel
周日的小讲堂要讲到这里,趁中午时间写点东西,记录昨天晚上完成的东西,在这里只是简单的介绍如何创建对于样式问题,我不过多的说,因为之后的教程会使用模版方式搞定! 在学习这段代码的时候,希望各位访问Apa ...
- 任何用户密码都能以sysdba角色登入
这是因为在安装Oracle的时候默认是使用了操作系统验证: 数据库用sysdba登录的验证有两种方式,一种是通过os认证,一种是通过密码文件验证:登录方式有两种,一种是在数据库主机直接登录(用os认证 ...
- js的alert抛出之后怎么让页面停止执行?
方法: 1.如果是form的submit提交,如果要停止,则返回false:如果提交,则返回true就行了. 2.如果是手工跳转的方式,则如果要停止,则不执行跳转代码:如果要提交,则执行跳转代码 示例 ...
- 51Nod 1013 3的幂的和 快速幂 | 乘法逆元 | 递归求和公式
1.乘法逆元 直接使用等比数列求和公式,注意使用乘法逆元 ---严谨,失细节毁所有 #include "bits/stdc++.h" using namespace std; #d ...
- 【C++对象模型】第六章 执行期语意学
执行期语意学,即在程序执行时,编译器产生额外的指令调用,确保对象的构造,内存的释放,以及类型转换与临时对象的生成的安全进行. 1.对象的构造和析构 对于类对象的构造,一般在定义之后则开始内部的构造过程 ...
- nginx与php-fpm通讯方式
nginx和php-fpm的通信方式有两种,一种是tcp socket的方式,一种是unix socke方式. tcp sockettcp socket的优点是可以跨服务器,当nginx和php-fp ...
- Zabbix 通过 JMX 监控 java 进程
参考: [ JMX monitoring ] [ Zabbix Java gateway ] [ JMX Monitoring (Java Gateway) not Working ] [ Monit ...
- 【洛谷 P1419】 寻找段落(二分答案,单调队列)
题目链接 开始还以为是尺取.发现行不通. 一看标签二分答案,恍然大悟. 二分一个\(mid\)(实数),把数列里每个数减去\(mid\),然后求前缀和,在用单调队列维护\(sum[i-t\text{~ ...
- response.getWriter().write()和 response.getWriter().print()的区别
异步上传图片的代码.发现里面用了response.getWriter().print(),故联想到response.getWriter().writer(),经过一番api的查找与实操,总结如下: r ...