题目翻译不好,这里给出一份

题目背景

Awson是某国际学校信竞组的一只大佬。由于他太大佬了,于是干脆放弃了考前最后的集训,开车(他可是老司机)去度假。离开学校前,他打开地图,打算做些规划。

题目描述

他发现整个地图中有N(1<=N<=20000)个地点。对于所有的路线,指定了其中K(1<=K<=200,K<=N)个地点作为收费站。他设计了M(1<=M<=20000 )种单向的路线,第i条路线从地点Ui至Vi收费为Di(1<=Di<=10000)。路线保证Ui或Vi至少有一个是收费站,且Ui≠Vi,任意两个地点至多有一条路线。现在Awson准备进行规划。共提出Q(1<=Q<=50000)个询问,其中第i个询问是从地点Ai至地点Bi。请帮助他计算,每个请求是否满足(是否从地点Ai至地点Bi有可行路线),并计算:能满足的度假询问的最小费用总和。

输入输出格式

输入格式:

第1行:四个整数N,M,K,Q

第2~M+1行:三个整数Ui,Vi,Di

第M+2~M+K+1行:收费站的编号X (0<=X<=N)

第M+K+2~M+K+Q+1:两个整数,度假询问Ai,Bi

输出格式:

第1行:能够满足的度假询问数

第2行:能满足的度假询问的最小费用总和

输入输出样例

输入样例:

3 3 1 2
1 2 10
2 3 10
2 1 5
2
1 3
3 1

输出样例:

1
20

说明

样例解释:

第1个询问,路线设计为1->2->3,费用为20
         第2个询问,无法满足

数据规模:

30%的数据有N<=100;

100%的数据有1<=N,M<=20000,1<=Q<=50000。

题解:

n很大,就算能O(1)求最短路也不行

但我们发现k很小,而且每条边至少有一个收费站

假设问u,v之间的最小距离,就是与u相邻的收费站与v的距离+边权

为包括u是收费站的情况,加入(u,u,0)边,修改部分会在代码中标记

题目转化为了求每个收费站到每个点的距离,用SPFA

复杂度为O(km+k*k)

询问部分可知一个点相邻的收费站最多为k,所以

询问复杂度为O(Q*k)

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
struct Node
{
int next,dis,to;
}edge[];
int head[],num,dist[][],q[],n,m,k,Q,p[],dis[][],b[],ans,cnt;
bool vis[];
void add(int u,int v,int d)
{
num++;
edge[num].next=head[u];
head[u]=num;
edge[num].to=v;
edge[num].dis=d;
}
void SPFA(int st,int j)
{int h,t,i;;
memset(dist[j],,sizeof(dist[j]));
memset(vis,,sizeof(vis));
q[]=st;
h=;t=;
dist[j][st]=;
while (h<t)
{
h++;
h%=;
int u=q[h];
vis[u]=;
for (i=head[u];i;i=edge[i].next)
{
int v=edge[i].to;
if (dist[j][v]>dist[j][u]+edge[i].dis)
{
dist[j][v]=dist[j][u]+edge[i].dis;
if (!vis[v])
{
t++;
t%=;
q[t]=v;
vis[v]=;
}
}
}
}
for (i=;i<=k;i++)
if (i!=j)
dis[j][i]=dist[j][p[i]];
}
int main()
{int i,j,u,v,d;
cin>>n>>m>>k>>Q;
edge[0].next=-1;
for (i=;i<=m;i++)
{
scanf("%d%d%d",&u,&v,&d);
add(u,v,d);
}
for (i=;i<=k;i++)
{
scanf("%d",&p[i]);
b[p[i]]=i;
}
for (i=;i<=k;i++)
{
SPFA(p[i],i);
}
while (Q--)
{
scanf("%d%d",&u,&v);
int s=1e9,x,y;
if (b[u]&&b[v])
{
s=dis[b[u]][b[v]];
}
else
for (i=head[u];i!=-1;i=edge[i].next)
{
82 if (b[u]) i=0;
83 if (i==0) x=u;
84 else x=edge[i].to;
if (b[x])
{
if (s>edge[i].dis+dist[b[x]][v])
s=edge[i].dis+dist[b[x]][v];
}
}
//cout<<s<<endl;
if (s<1e9)
ans+=s,cnt++;
}
cout<<cnt<<endl<<ans;
}

[USACO13DEC]假期计划(黄金)Vacation Planning (gold)的更多相关文章

  1. 洛谷P3094 [USACO13DEC]假期计划Vacation Planning

    题目描述 有N(1 <= N <= 200)个农场,用1..N编号.航空公司计划在农场间建立航线.对于任意一条航线,选择农场1..K中的农场作为枢纽(1 <= K <= 100 ...

  2. [USACO 13DEC]Vacation Planning(gold)

    Description Air Bovinia operates flights connecting the N farms that the cows live on (1 <= N < ...

  3. P4824 [USACO15FEB]Censoring (Silver) 审查(银)&&P3121 [USACO15FEB]审查(黄金)Censoring (Gold)

    P3121 [USACO15FEB]审查(黄金)Censoring (Gold) (银的正解是KMP) AC自动机+栈 多字符串匹配--->AC自动机 删除单词的特性--->栈 所以我们先 ...

  4. bzoj 4097: [Usaco2013 dec]Vacation Planning

    4097: [Usaco2013 dec]Vacation Planning Description Air Bovinia is planning to connect the N farms (1 ...

  5. hihoCoder#1698 : 假期计划 组合数

    题面:hihoCoder#1698 : 假期计划  组合数 题解: 题目要求是有序的排列,因此我们可以在一开始就乘上A!*B!然后在把这个序列划分成很多段. 这样的话由于乘了阶乘,所以所有排列我们都已 ...

  6. 洛谷P1360 [USACO07MAR]黄金阵容均衡Gold Balanced L…

    P1360 [USACO07MAR]黄金阵容均衡Gold Balanced L… 题目描述 Farmer John's N cows (1 ≤ N ≤ 100,000) share many simi ...

  7. 「USACO15FEB」「LuoguP3121」审查(黄金)Censoring (Gold)(AC自动机

    题目描述 Farmer John has purchased a subscription to Good Hooveskeeping magazine for his cows, so they h ...

  8. 洛谷 P1360 [USACO07MAR]黄金阵容均衡Gold Balanced L…

    P1360 [USACO07MAR]黄金阵容均衡Gold Balanced L… 题目描述 Farmer John's N cows (1 ≤ N ≤ 100,000) share many simi ...

  9. hihocoder #1698 假期计划 (排列组合+费马小定理+乘法逆元)

    Description 小Ho未来有一个为期N天的假期,他计划在假期中看A部电影,刷B道编程题.为了劳逸结合,他决定先拿出若干天看电影,再拿出若干天刷题,最后再留若干天看电影.(若干代指大于0)  每 ...

随机推荐

  1. 团队作业7——第二次项目冲刺(Beta版本12.08)

    项目每个成员的进展.存在问题.接下来两天的安排. 已完成的内容:完成了排行榜的测试.上传头像功能的原型设计.界面优化 计划完成的内容:上传头像功能开发.测试.头像裁剪原型设计 每个人的工作 (有wor ...

  2. Alpha冲刺Day5

    Alpha冲刺Day5 一:站立式会议 今日安排: 首先由于经过黄腾飞短暂的测试,发现导入导出仍然有一些问题,今天需要进行完善 由黄腾飞负责企业自查风险管理子模块,要求为单元进行风险点的管理 由张梨贤 ...

  3. 学号:201621123032 《Java程序设计》第10周学习总结

    1:本周学习总结 1.1.:以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. 2:书面作业 2.1.:常用异常--结合题集题目7-1回答 2.1.1:自己以前编写的代码中经常出现什么异常.需要捕 ...

  4. centos7 编译安装greenplum5.7

    一.配置系统 安装是以一个主节点,三个子节点进行安装.gp是在github上下载的5.7的源码.地址https://github.com/greenplum-db/gpdb/tree/5.7.0. 1 ...

  5. 04_Linux目录文件操作命令1(mv ls cd...)_我的Linux之路

    上一节已经给大家讲了Linux的目录结构,相信大家已经对Linux的整个目录结构有所了解 现实中,服务器(包含Linux,Unix,windows server)一般都摆放在机房里,因为一个机房摆放了 ...

  6. 数据库 MYSQL操作(一)

    数据库  MYSQL操作总结(一) 本文主要介绍一下笔者在使用数据库操作的过程中的一些总结,主要的内容包括一下几个内容: 一.mysql 使用基础(主要包括数据库的安装.基本操作等内容) 二.mysq ...

  7. Spring Security 入门(1-2)Spring Security - 从 配置例子例子 开始我们的学习历程

    1.Spring Security 的配置文件 我们需要为 Spring Security 专门建立一个 Spring 的配置文件,该文件就专门用来作为 Spring Security 的配置. &l ...

  8. Python 自动化 第一周

    1.Python简介 1.1.Python介绍 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆(中文名字:龟叔)为了在阿姆斯特丹打发时 ...

  9. js基本包装类型和引用类型

    回顾 1.什么是基本类型? 共5个.boolean,string,number,null,undefined. 2.什么是引用类型? 引用类型的值是对象,保存在堆内存中: 引用类型的变量实际上是一个指 ...

  10. Mysql 5.1的坑

    1.数据库表是区分大小写的 之前程序在5.7数据库没问题,测试环境上数据库是5.1的,就提示表找不到. 2.同样的sql,在5.1上会提示事务获取锁失败,超时返回.而5.7上正常.原因暂未找到.