(全国多校重现赛一)F-Senior Pan
Senior Pan fails in his discrete math exam again. So he asks Master ZKC to give him graph theory problems everyday.
The task is simple : ZKC will give Pan a directed graph every time, and selects some nodes from that graph, you can calculate the minimum distance of every pair of nodes chosen in these nodes and now ZKC only cares about the minimum among them. That is still too hard for poor Pan, so he asks you for help.
Input
The first line contains one integer T, represents the number of Test Cases.1≤T≤5.Then T Test Cases, for each Test Cases, the first line contains two integers n,m representing the number of nodes and the number of edges.1≤n,m≤100000
Then m lines follow. Each line contains three integers xi,yixi,yi representing an edge, and vivi representing its length.1≤xi,yixi,yi≤n,1≤vivi≤100000
Then one line contains one integer K, the number of nodes that Master Dong selects out.1≤K≤n
The following line contains K unique integers aiai, the nodes that Master Dong selects out.1≤aiai≤n,aiai!=aj
Output
For every Test Case, output one integer: the answer
Sample Input
1
5 6
1 2 1
2 3 3
3 1 3
2 5 1
2 4 2
4 3 1
3
1 3 5
Sample Output
Case #1: 2
题意:给你一个无向图,然后给你K个数字,然后让你求任意两点之间的最短距离,并输出这些最短距离的最小值;
题解:首先考虑最短路径的算法,Foyld肯定不行O(n^3);Dijkstra与SPFA都是O(nlog(n))。然后由于K的范围是10^5级别的
如果暴力跑Dijkstra的话 n*(n+1)/2次。。。。 我们可以考虑二进制,任意两个数字至少有一位是不同的,所以我们枚举每一位上不同的点(也就17次就够了),将其分别放入两个集合,建立超级源点(0),和超级汇点(n+1),分别将两个集合与超级源点和超级汇点相连,距离为0,这样Dijkstra的单源多汇最短路就变为了,多源多汇最短路了,然后用优先队列优化的Dijkstra跑最短路即可,也就17*2次,O(nlog(n)),时间复杂度满足要求;
参考代码如下:
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL INF=0x3f3f3f3f3f3f3f3fLL;
const int maxn=1e5+10;
int n,m,k,tot;
int u[maxn],v[maxn],vis[maxn],head[maxn],num[maxn];
LL w[maxn],dis[maxn];
struct Edge{
int u,v;
LL w;
Edge(int uu,int vv,LL ww) : u(uu),v(vv),w(ww) { }
};
vector<Edge> vec[maxn];
struct Node{
int id;
LL W;
bool operator < (const Node &b) const
{
return W>b.W;
}
};
void addedge(int u,int v,LL w)
{
vec[u].push_back(Edge(u,v,w));
}
priority_queue<Node> q;
LL Dijkstra()
{
memset(vis,0,sizeof vis);
memset(dis,INF,sizeof dis);
dis[0]=0;
q.push(Node{0,0} );
while(!q.empty())
{
Node u=q.top(); q.pop();
int Id=u.id;
if(vis[Id]) continue;
vis[Id]=1;
for(int i=0;i<vec[Id].size();i++)
{
if(!vis[vec[Id][i].v] && dis[vec[Id][i].v]>dis[Id]+vec[Id][i].w)
{
dis[vec[Id][i].v]=dis[Id]+vec[Id][i].w;
q.push(Node{vec[Id][i].v,dis[vec[Id][i].v]});
}
}
}
return dis[n+1];
}
void Init()
{
tot=0;
memset(head,-1,sizeof head);
for(int i=0;i<=n+1;i++) vec[i].clear();
}
int main()
{
int Cas=0,T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++) scanf("%d%d%lld",u+i,v+i,w+i);
scanf("%d",&k);
for(int i=1;i<=k;i++) scanf("%d",num+i);
LL ans=INF;
for(int bit=0;bit<=17;bit++)
{
Init();
for(int i=1;i<=m;i++) addedge(u[i],v[i],w[i]);
for(int i=1;i<=k;i++)
{
if(num[i]&(1<<bit)) addedge(0,num[i],0);
else addedge(num[i],n+1,0);
}
ans=min(ans,Dijkstra());
Init();
for(int i=1;i<=m;i++) addedge(u[i],v[i],w[i]);
for(int i=1;i<=k;i++)
{
if((num[i]&(1<<bit))==0) addedge(0,num[i],0);
else addedge(num[i],n+1,0);
}
ans=min(ans,Dijkstra());
}
printf("Case #%d: %lld\n",++Cas,ans);
}
return 0;
}
(全国多校重现赛一)F-Senior Pan的更多相关文章
- (全国多校重现赛一)B-Ch's gifts
Mr. Cui is working off-campus and he misses his girl friend very much. After a whole night tossing a ...
- (全国多校重现赛一)D Dying light
LsF is visiting a local amusement park with his friends, and a mirror room successfully attracts his ...
- (全国多校重现赛一) J-Two strings
Giving two strings and you should judge if they are matched. The first string contains lowercase le ...
- (全国多校重现赛一) H Numbers
zk has n numbers a1,a2,...,ana1,a2,...,an. For each (i,j) satisfying 1≤i<j≤n, zk generates a new ...
- (全国多校重现赛一)E-FFF at Valentine
At Valentine's eve, Shylock and Lucar were enjoying their time as any other couples. Suddenly, LSH, ...
- (全国多校重现赛一)A-Big Binary Tree
You are given a complete binary tree with n nodes. The root node is numbered 1, and node x's father ...
- 长春理工大学第十四届程序设计竞赛(重现赛)F.Successione di Fixoracci
链接:https://ac.nowcoder.com/acm/contest/912/F 题意: 动态规划(Dynamic programming,简称dp)是一种通过把原问题分解为相对简单的子问题的 ...
- 长春理工大学第十四届程序设计竞赛(重现赛)F
F. Successione di Fixoracci 题目链接:https://ac.nowcoder.com/acm/contest/912/F 题目: 动态规划(Dynamic programm ...
- 2019年湘潭大学程序设计竞赛(重现赛)F.Black&White
传送门 F.Black&White •题意 操作 m 次后,求连续的1或连续的0的最大值,每次操作只能反转一个位置: •思路1(反悔操作) 定义队列q:依次存放两个零之间的1的个数+1: 首先 ...
随机推荐
- java-optional-快速使用-教程
前言: 在公司中开发项目时碰到一个从Java8引入的一个Optional类,以前jdk版本使用的比较低,没有使用过,于是我在网上浏览了一些文档写篇文章学习总结一下,希望没有用过的朋友们都能够快速学习到 ...
- maven的项目结构
1.标准目录结构: src -main –bin 脚本库 –java java源代码文件 –resources 资源库,会自动复制到classes目录里 ...
- linux环境中,两个不同网段的机器互通
linux环境中,两个不同网段的机器互通 人评论3690人阅读2019-11-18 14:50:21 环境如下: host1 单网卡 eth0 172.24.100.15/16 hos ...
- Jenkins+pipeline+参数构建+人工干预确定
Jenkins+pipeline+参数构建+人工干预 实现了以下功能 1. 可以选择环境,单选:可以选择需要发布的项目,多选 2.发布过程可视化 3. 可以人工干预是否继续发布. 初始化配置需要很久, ...
- JenKins结合cppcheck及cpplint进行代码风格及静态代码检测
JenKins结合cppcheck及cpplint 最近公司需要在Jenkins上安装cppcheck及cpplint进行代码风格及静态代码检测,这里记录下过程. 前提条件 安装了Jenkins 步骤 ...
- volatile变量能保证线程安全性吗?为什么?
在谈及线程安全时,常会说到一个变量——volatile.在<Java并发编程实战>一书中是这么定义volatile的——Java语言提供了一种稍弱的同步机制,即volatile变量,用来确 ...
- ArcGIS API For Javascript:热力图不同级别下的优化方法
我们在地图缩放的不同级别下,热力图的显示效果会不同,由于点密度与模糊参数默认是固定的,因此需要对参数进行动态修改,以满足不同缩放级别下可以得到较好的显示效果. 思路是监听地图缩放级别,将地图缩放级别作 ...
- 系统信息命令(uname、dmesg、df、hostname、free)
uname 显示计算机及操作系统相关的信息,uname -a显示全部信息,uname -r内核的发行号,各种信息可以有单独的选项分别指出 [lixn@Fedora24 ~]$ uname -a Lin ...
- C语言程序设计100例之(17):百灯判亮
例17 百灯判亮 问题描述 有序号为1.2.3.….99.100的100盏灯从左至右排成一横行,且每盏灯各由一个拉线开关控制着,最初它们全呈关闭状态.有100个小朋友,第1位走过来把凡是序号为1的 ...
- C++程序的耦合性设计
声明:本文部分采用和参考<代码里的世界观-通往架构师之路>中内容,可以说是该书中耦合性一章的读后感,感谢该书的作者余叶老师的无私分享. 1.什么是耦合? 耦合其实就是程序之间的相关性. 程 ...