【2019南昌网络赛】B-Fire-Fighting Hero
分析
英雄方面很简单,跑一遍 Dijkstra 就行了,但是灭火团队就有点麻烦了。
这里可以借助一下最大流的建边来解决这个问题:
我们可以另外找一个点作为起点,然后建立从那个点到每一个团队的起点的边,权值为0,这样就完成了多起点的最短路
恰好我的板子是封装好的 Dijkstra ,我就直接建立两个结构体解决问题,因为点的数量只有 1000 个,空间上已经没有什么顾虑了
AC-Code
#include <bits/stdc++.h>
using namespace std;
#define MAXN 1100
#define MAXM 1000000
#define INF 0x3fffffff //防止后面溢出,这个不能太大
struct Graph {
struct Edge {
long long to, next;
long long cost;
} edge[MAXM];
long long head[MAXN];
long long tot;
void init(long long n) {
tot = 0;
memset(head, -1, sizeof(long long) * (n + 1));
}
void add_edge(long long from, long long to, long long value) {
edge[tot].to = to;
edge[tot].cost = value;
edge[tot].next = head[from];
head[from] = tot++;
}
};
struct Dijkstra {
long long low_cost[MAXN];
bool vis[MAXN];
long long pre[MAXN];
void solve(long long b, long long e, long long start, Graph &graph) {
for (long long i = b; i < e; i++) {
low_cost[i] = INF;
vis[i] = false;
pre[i] = -1;
}
low_cost[start] = 0;
vis[start] = true;
long long cur_edge = graph.head[start];
while (cur_edge != -1) {
if (!vis[graph.edge[cur_edge].to] &&
low_cost[start] + graph.edge[cur_edge].cost < low_cost[graph.edge[cur_edge].to]) {
low_cost[graph.edge[cur_edge].to] = low_cost[start] + graph.edge[cur_edge].cost;
pre[graph.edge[cur_edge].to] = start;
}
cur_edge = graph.edge[cur_edge].next;
}
for (long long j = b; j < e - 1; j++) {
long long k = -1;
long long Min = INF;
for (long long i = b; i < e; i++) {
if (!vis[i] && low_cost[i] < Min) {
Min = low_cost[i];
k = i;
}
}
if (k == -1)
break;
vis[k] = true;
cur_edge = graph.head[k];
while (cur_edge != -1) {
if (!vis[graph.edge[cur_edge].to] &&
low_cost[k] + graph.edge[cur_edge].cost < low_cost[graph.edge[cur_edge].to]) {
low_cost[graph.edge[cur_edge].to] = low_cost[k] + graph.edge[cur_edge].cost;
pre[graph.edge[cur_edge].to] = k;
}
cur_edge = graph.edge[cur_edge].next;
}
}
}
};
Graph graph;
Dijkstra dijkstra1, dijkstra2;
int k_node[MAXN];
void solve() {
long long t;
cin >> t;
long long v, e, s, k, c;
for (int ts = 0; ts < t; ++ts) {
cin >> v >> e >> s >> k >> c;
graph.init(v + 1);
for (int i = 0; i < k; ++i) {
cin >> k_node[i];
}
long long from, to, value;
for (long long i = 0; i < e; ++i) {
cin >> from >> to >> value;
graph.add_edge(from, to, value);
graph.add_edge(to, from, value);
}
dijkstra1.solve(1, v + 1, s, graph);//第一次跑dijkstra
for (int i = 0; i < k; ++i) {
graph.add_edge(0, k_node[i], 0); // 这里设定超级源点为0,建立从0到每一个团队起点的边,权值为0
}
dijkstra2.solve(0, v + 1, 0, graph);//第二次跑dijkstra
long long s_min_max = 0;
for (long long i = 1; i < v + 1; ++i)
s_min_max = max(s_min_max, dijkstra1.low_cost[i]);
long long k_min_max = 0;
for (long long i = 1; i < v + 1; ++i)
k_min_max = max(k_min_max, dijkstra2.low_cost[i]);
if (s_min_max <= c * k_min_max)//考虑到精度问题,这里用乘法代替
cout << s_min_max << endl;
else
cout << k_min_max << endl;
}
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
#ifdef ACM_LOCAL
freopen("in.txt", "r", stdin);
freopen("out.txt", "w", stdout);
long long test_index_for_debug = 1;
char acm_local_for_debug;
while (cin >> acm_local_for_debug) {
cin.putback(acm_local_for_debug);
if (test_index_for_debug > 100) {
throw runtime_error("Check the stdin!!!");
}
auto start_clock_for_debug = clock();
cout << "Test " << test_index_for_debug << ":" << endl;
solve();
auto end_clock_for_debug = clock();
cerr << "Test " << test_index_for_debug++ << " Run Time: "
<< double(end_clock_for_debug - start_clock_for_debug) / CLOCKS_PER_SEC << "s" << endl;
cout << "\n--------------------------------------------------" << endl;
}
#else
solve();
#endif
return 0;
}
【2019南昌网络赛】B-Fire-Fighting Hero的更多相关文章
- 2019南昌网络赛I:Yukino With Subinterval(CDQ) (树状数组套主席树)
题意:询问区间有多少个连续的段,而且这段的颜色在[L,R]才算贡献,每段贡献是1. 有单点修改和区间查询. 思路:46min交了第一发树套树,T了. 稍加优化多交几次就过了. 不难想到,除了L这个点, ...
- ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval
ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval 题目大意:给一个长度为n,值域为[1, n]的序列{a},要求支持m次操作: 单点修改 1 pos val 询 ...
- ACM-ICPC 2019南昌网络赛F题 Megumi With String
ACM-ICPC 南昌网络赛F题 Megumi With String 题目描述 给一个长度为\(l\)的字符串\(S\),和关于\(x\)的\(k\)次多项式\(G[x]\).当一个字符串\(str ...
- 2019南昌网络赛 hello 2019
这道题和一道2017,2016的类似. A string t is called nice if a string “2017” occurs in t as a subsequence but a ...
- 2019南昌网络赛G. tsy's number
题意:\(\sum_{i=1}^n\sum_{j=1}^n\sum_{k=1}^n\frac{\phi(i)*\phi(j^2)*\phi(k^3)}{\phi(i)*\phi(j)*\phi(k)} ...
- 2019南昌网络赛-I(单调栈+线段树)
题目链接:https://nanti.jisuanke.com/t/38228 题意:定义一段区间的值为该区间的和×该区间的最小值,求给定数组的最大的区间值. 思路:比赛时还不会线段树,和队友在这题上 ...
- 2019南昌网络赛-M(二分)
题目链接:https://nanti.jisuanke.com/t/38232 题意:给定字符串s(长度<=1e5),然后N组样例(N<=1e5),每组输入一个字符串t判断t是否为s的字串 ...
- 2019南昌网络赛H The Nth Item(打表找询问循环节 or 分段打表)
https://nanti.jisuanke.com/t/41355 思路 从fib循环节入手,\(O(1e7log(1e9))\),tle 因为只需要输出所有询问亦或后的结果,所以考虑答案的循环节, ...
- 2019南昌网络赛 I. Yukino With Subinterval 树状数组套线段树
I. Yukino With Subinterval 题目链接: Problem Descripe Yukino has an array \(a_1, a_2 \cdots a_n\). As a ...
随机推荐
- 3名程序员被抓!开发“万能钥匙”APP,撬走3个亿
来自:程序员头条 报道 又有 3 名程序员被抓!开发"万能钥匙"APP,撬走 3 亿! 前几天,据央视新闻报道,上海公安机关接到共享单车企业报案,随后破获了一起共享单车万能解锁 A ...
- 机器学习算法的基本知识(使用Python和R代码)
本篇文章是原文的译文,然后自己对其中做了一些修改和添加内容(随机森林和降维算法).文章简洁地介绍了机器学习的主要算法和一些伪代码,对于初学者有很大帮助,是一篇不错的总结文章,后期可以通过文中提到的算法 ...
- OpenStack官方镜像无法ssh登陆
0x00 序 当前主流的Linux系统都有提供可以在OpenStack中直接使用cloud镜像,但当使用从官方网站下载的镜像创建云主机时,你会发现Linux下经常使用的ssh竟然无法登陆新创建好的云主 ...
- 查漏补缺:Vector中去重
对于STL去重,可以使用<algorithm>中提供的unique()函数. unique()函数用于去除相邻元素中的重复元素(所以去重前需要对vector进行排序),只留下一个.返回去重 ...
- WEB前端工程师简历
一个热爱前端的工程师 关于我 我的作品 ZENRON 关于我 求职意向 作品集 技术掌握 我的经历 联系我 关于我 英语/CET-4 坐标/苏州 状态/求职 我叫Zenron, 现居住苏州, 是一名前 ...
- 如何应对HR小姐姐的千年历史遗留问题:你为什么从上家公司离职?
最近找我询问面试问题的学生比较多,而且问的问题基本上都是课堂上讲过的,好吧,在此心疼自己三秒钟. 那么今天就为各位宝宝们整理一下,如何优雅的回复HR小姐姐的这个千年历史遗留问题:你为什么从上家公司离职 ...
- <pre>标签的使用
做做笔记.碰见了一个网站,显示代码的时候自带语法高亮,这很新鲜.它的代码被pre标签包裹,原本以为pre标签下的所有的内容会以文本原来的样式输出,特意查了查发现它依然支持html标签. 先来个菜鸟教程 ...
- wepack环境配置1之node的安装
.向往已久的webpack终于配好了.. 1.要安装webpack,首先需要安装nodejs nodejs下载地址:https://nodejs.org/en/ 下载完成后,一步步安装即可,我是安装到 ...
- TCP传输连接管理
TCP传输连接管理 一.传输连接的三个阶段 1.1.概述 传输连接就有三个阶段,即:连接建立.数据传送和连接释放. 连接建立过程中要解决以下三个问题: 要使每一方能够确知对方的存在. 要允许双方协商一 ...
- 修改gridfilters.js源码,往后台多传递一个参数,并设置NumericFilter、StringFilter默认提示信息
创作不易,转载请注明出处!!! 效果 修改:ext-extend.js源码 在最后面添加3行,重写方法 代码拷贝区 Ext.override(Ext.ux.grid.GridFilters, { me ...