博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
temporary
阅读量:4664 次
发布时间:2019-06-09

本文共 1590 字,大约阅读时间需要 5 分钟。

#define _CRT_SECURE_NO_WARNINGS#include 
#include
#include
#include
using namespace std;int n, m, s, d;int e[510][510], cost[510][510], dis[510];int inf = 999999999;bool visit[510];vector
pre[510], temppath, path;int finalcost=inf;void dfs(int vv) { temppath.push_back(vv); if (vv == s) { int tempcost=0; for (int i = temppath.size()-1; i >0; i--) { int id = temppath[i], nextid = temppath[i - 1]; tempcost += cost[id][nextid]; } if (tempcost
> n >> m >> s >> d; fill(e[0], e[0] + 510 * 510, inf); //fill(cost[0], cost[0] + 510 * 510, inf); fill(dis, dis+510, inf); //fill(visit, visit + 510, false); for (int i = 0; i < m; i++) { int a, b; scanf("%d%d", &a, &b); scanf("%d", &e[a][b]); e[b][a] = e[a][b]; scanf("%d", &cost[a][b]); cost[b][a] = cost[a][b]; } /*for (int i = 0; i < m; i++) { int c1, c2, di, co; cin >> c1 >> c2 >> di >> co; e[c1][c2] = e[c2][c1] = di; cost[c1][c2] = cost[c2][c1] = co; }*/ pre[s].push_back(s); dis[s] = 0; for (int i = 0; i < n; i++) { int u = -1, min = inf; for (int j = 0; j < n; j++) { if (visit[j] == false &&dis[j]
dis[u] + e[u][v]) { dis[v] = dis[u] + e[u][v]; pre[v].clear(); pre[v].push_back(u); } else if (dis[v] == dis[u] + e[u][v]) { pre[v].push_back(u); } } } dfs(d); for (int i = path.size() - 1; i >= 0; i--) printf("%d ", path[i]); printf("%d %d", dis[d], finalcost); } return 0;}

 

转载于:https://www.cnblogs.com/masayoshi/p/10867303.html

你可能感兴趣的文章
提示constructor无法location的原因
查看>>
【JavaScript】 闭包 我战战兢兢的接触了它
查看>>
easyui datagrid 去除单击行选中事件
查看>>
windows 环境下搭建django 错误分析总结
查看>>
恩,让我们来看一下你的布局8!
查看>>
回退Ubuntu记录
查看>>
cmd命令往MySQL数据库提交数据
查看>>
configure & make & make install
查看>>
Java_基础—LineNumberReader
查看>>
week_ptr和checked_delete
查看>>
测试架构师
查看>>
TreeView展开所有节点
查看>>
vs绑定和取消绑定项目和解决方案
查看>>
C# 自定义集合
查看>>
修改git提交的用户名和密码
查看>>
Android Studio 生成aar包多Module引用问题
查看>>
AOP静态代理解析2-代码织入
查看>>
asp.net2.0导出pdf文件完美解决方案【转载】
查看>>
JavaWeb过滤器.监听器.拦截器-原理&区别(转)
查看>>
CentOS中yum安装ffmpeg
查看>>