(全国多校重现赛一)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: 首先 ...
随机推荐
- 正则表达式 解决python2升python3的语法问题
2019.9.12 更新 今天偶然看到 python 官网中,还介绍了一个专门的工具,用于 python2 升级 python3,以后有机会使用下看看 https://docs.python. ...
- jenkins手把手教你从入门到放弃01-jenkins简介(详解)
一.简介 jenkins是一个可扩展的持续集成引擎.持续集成,也就是通常所说的CI(Continues Integration),可以说是现代软件技术开发的基础.持续集成是一种软件开发实践, 即团队开 ...
- RHEL7.2 SSH无密码登录非root用户
1 修改三台虚拟机的/ect/hosts文件 [hadoop@hadoop01 ~]$ cat /etc/hosts 127.0.0.1 localhost localhost.localdomain ...
- Win32 COM组件 x Android Service
有些书在介绍和讲解android的Service组件时,会使用后台服务一词,并且与运行在主线程的Activity相对.因为后台一词很容易误解,服务一直运行在后台?什么线程在运行?服务一直有条线程在运行 ...
- inventory
1.设置主机的默认inventory mode. 2. 设置自动Populate 数据
- 扛把子组20191031-8 alpha week 1/2 Scrum立会报告+燃尽图 06
此作业的要求参见:https://edu.cnblogs.com/campus/nenu/2019fall/homework/9916 一.小组情况 队名:扛把子 组长:孙晓宇 组员:宋晓丽 梁梦瑶 ...
- Asis CTF 2016 b00ks理解
---恢复内容开始--- 最近在学习堆的off by one,其中遇到这道题,萌新的我弄了大半天才搞懂,网上的很多wp都不是特别详细,都得自己好好调试. 首先,这题目是一个常见的图书馆管理系统,虽然我 ...
- React中使用create-react-app创建项目,运行npm run eject建立灰度报错
我在运行npm run eject建立测试环境和正式环境时候报错 这里的问题是是脚手架添加.gitgnore文件,但是却没有本地仓库,按照以下顺序就可以正常使用 git add . git commi ...
- 剖析nsq消息队列(四) 消息的负载处理
剖析nsq消息队列-目录 实际应用中,一部分服务集群可能会同时订阅同一个topic,并且处于同一个channel下.当nsqd有消息需要发送给订阅客户端去处理时,发给哪个客户端是需要考虑的,也就是我要 ...
- Java常用类、接口关系图谱
呕心沥血画出此图,希望在使用Java类.接口时捋顺其关系,从而更好的组织程序逻辑---请看图 Object分出来的类都是其子类 Iterable接口分出的也是子接口 从继承关系分析,其父类实现的接口子 ...