ZOJ 3946 Highway Project 贪心+最短路
题目链接:
http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=3946
题解:
用dijkstra跑单元最短路径,如果对于顶点v,存在一系列边(ui,v)使得dis[v]最小(dis[v]表示0到v的距离)。这些边能且只能选一条,那么我们自然应该选cost最小的那个边了。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
#include<algorithm>
#include<queue>
using namespace std; typedef long long LL;
const int maxn = 1e5 + ; struct Edge {
int ne, u, v, c, d;
Edge(int ne, int u, int v, int d, int c) :ne(ne), u(u), v(v), d(d), c(c) {}
Edge() {}
}egs[maxn * ]; struct Heap {
int u, d, c;
Heap(int u, int d) :u(u), d(d) {}
Heap() {}
bool operator < (const Heap& tmp) const {
return d>tmp.d;
}
}; struct Node {
int u, v, w;
bool operator < (const Node& tmp) const {
return w<tmp.w;
}
}nds[maxn]; int head[maxn], tot; void addEdge(int u, int v, int d, int c) {
egs[tot] = Edge(head[u], u, v, d, c);
head[u] = tot++;
} int n, m;
LL ans_d, ans_c; LL dis[maxn];
//pre[u]记录u和前驱节点的那条边的cost
int pre[maxn];
bool done[maxn]; void dij() {
for (int i = ; i<n; i++) {
dis[i] = 2e10;
}
memset(done, false, sizeof(done));
priority_queue<Heap> pq;
dis[] = ;
pq.push(Heap(, ));
while (!pq.empty()) {
Heap x = pq.top(); pq.pop();
int u = x.u;
if (done[u]) continue;
done[u] = true;
int p = head[u];
while (p != -) {
Edge &e = egs[p];
if (dis[e.v]>dis[u] + e.d) {
dis[e.v] = dis[u] + e.d;
pre[e.v] = e.c;
pq.push(Heap(e.v, dis[e.v]));
}
else if (dis[e.v] == dis[u] + e.d) {
//这里贪心选cost最小的边
if (pre[e.v]>e.c)
pre[e.v] = e.c;
}
p = e.ne;
}
}
ans_d = ; ans_c = ;
for (int i = ; i<n; i++) {
ans_d += dis[i];
}
for (int i = ; i<n; i++) {
ans_c += pre[i];
}
} void init() {
memset(head, -, sizeof(head));
memset(pre, -, sizeof(pre));
tot = ;
} int main() {
// freopen("data_in.txt","r",stdin);
int tc;
scanf("%d", &tc);
while (tc--) {
scanf("%d%d", &n, &m);
init();
for (int i = ; i<m; i++) {
int u, v, d, c;
scanf("%d%d%d%d", &u, &v, &d, &c);
addEdge(u, v, d, c);
addEdge(v, u, d, c);
}
dij();
printf("%lld %lld\n", ans_d, ans_c);
}
return ;
}
ZOJ 3946 Highway Project 贪心+最短路的更多相关文章
- ZOJ 3946.Highway Project(The 13th Zhejiang Provincial Collegiate Programming Contest.K) SPFA
ZOJ Problem Set - 3946 Highway Project Time Limit: 2 Seconds Memory Limit: 65536 KB Edward, the ...
- zoj 3946 Highway Project(最短路 + 优先队列)
Highway Project Time Limit: 2 Seconds Memory Limit: 65536 KB Edward, the emperor of the Marjar ...
- ZOJ 3946 Highway Project(Dijkstra)
Highway Project Time Limit: 2 Seconds Memory Limit: 65536 KB Edward, the emperor of the Marjar ...
- ZOJ 3946 Highway Project (最短路)
题意:单源最短路,给你一些路,给你这些路的长度,给你修这些路的话费,求最短路和最小花费. 析:本质就是一个最短路,不过要维护两个值罢了,在维护花费时要维护的是该路要花多少,而不是总的路线花费. 代码如 ...
- ZOJ 3946 Highway Project
1.迪杰斯特拉最小堆 #include<cstdio> #include<cstring> #include<cmath> #include<map> ...
- ZOJ3946:Highway Project(最短路变形)
本文转载自:http://www.javaxxz.com/thread-359442-1-1.html Edward, the emperor of the Marjar Empire, wants ...
- ZOJ-3946 Highway Project (最短路)
题目大意:一张带权无向图,权有两个参数(d,c),分别表示走过这条边的时间和建造这条边的代价.要求选出一些边,使得0节点到其他点的距离之和最短,并在最短的基础上求最小代价. 题目分析:这是16年浙江省 ...
- (spfa) Highway Project (zoj 3946 )
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5718 Highway Project Time Limit: 2 Seco ...
- hdu1874 畅通project续 最短路 floyd或dijkstra或spfa
Problem Description 某省自从实行了非常多年的畅通project计划后.最终修建了非常多路.只是路多了也不好,每次要从一个城镇到还有一个城镇时,都有很多种道路方案能够选择.而某些方案 ...
随机推荐
- javascript对象定义及创建
javascript对象 定义 javascript中的对象,可以理解成是一个键值对的集合,键是调用每个值的名称,值可以是基本变量,还可以是函数和对象. 创建方法 第一种方法 通过顶级Object类来 ...
- Angular 弹窗 控件
这个控件个人很喜欢,比起primgNG等弹窗组建,这款弹窗可以很轻松的定义自己的样式和布局. 可控参数有:宽度,高度,是否带有关闭图标,基本满足基础弹窗需求. 并且 Title/Content/Foo ...
- TP5.0中多图上传文件名重复问题
最近在做项目的时候出现了一个问题,这里记录一下: 问题: 使用TP5.0框架自带的文件上传方法后,发现多图上传可能会出现文件名重复的问题. 问题代码: 找到TP5框架上传文件命名方法,/thinkph ...
- day 32 管道,信号量,进程池,线程的创建
1.管道(了解) Pipe(): 在进程之间建立一条通道,并返回元组(conn1,conn2),其中conn1,conn2表示管道两端的连接对象,强调一点:必须在产生Process对象之前产生管道. ...
- 大数据 : Hadoop reduce阶段
Mapreduce中由于sort的存在,MapTask和ReduceTask直接是工作流的架构.而不是数据流的架构.在MapTask尚未结束,其输出结果尚未排序及合并前,ReduceTask是又有数据 ...
- scRNA-seq genomic analysis pipline
a scRNA-seq genomic anlysis pipline .caret,.dropup>.btn>.caret{border-top-color:#000!important ...
- FPGA之CORDIC算法实现_代码实现(下)
关于FPGA之CORDIC算法的纯逻辑实现,博主洋葱洋葱“https://www.cnblogs.com/cofin/p/9188629.html”以及善良的一休军“https://blog.csdn ...
- 20155209 实验三 敏捷开发与XP实践
20155209 实验三 敏捷开发与XP实践 实验内容 1. XP基础 2. XP核心实践 3. 相关工具 提交点一: 在IDEA中使用工具(Code->Reformate Code)把下面代码 ...
- day 2 函数的嵌套
1.函数的嵌套 百度百科 2.产品如何运作 3.应用 1)版本1:打印1条线 #1.定义函数 def print_line(): print("-"*50) #2.调用函数 ...
- CF543E Listening to Music
题面 空间只有$64\text{MB}$!!! 题解 (据说正解是毒瘤分块套分块) 按照权值从大到小排序,对所有能够覆盖到它的区间的左端点打个标记 按照值域建一棵主席树就可以了 区间查询最大值,用$m ...