题目

BOSS送给小唐一辆车。小唐开着这辆车从PKU出发去ZJU上课了。

众所周知,天朝公路的收费站超多的。经过观察地图,小唐发现从PKU出发到ZJU的所有路径只会有N(2<=N<=300)个不同的中转点,其中有M(max(0, N-100) <=M<=N)个点是天朝的收费站。N个中转点标号为1…N,其中1代表PKU,N代表ZJU。中转点之间总共有E(E<=50,000)条双向边连接。

每个点还有一个附加属性,用0/1标记,0代表普通中转点,1代表收费站。当然,天朝的地图上面是不会直接告诉你第i个点是普通中转点还是收费站的。地图上有P(1<=P<=3,000)个提示,用[u, v, t]表示:[u, v]区间的所有中转点中,至少有t个收费站。数据保证由所有标记得到的每个点的属性是唯一的。

车既然是BOSS送的,自然非比寻常了。车子使用了世界上最先进的DaxiaYayamao引擎,简称DY引擎。DY引擎可以让车子从U瞬间转移到V,只要U和V的距离不超过L(1<=L<=1,000,000),并且U和V之间不能有收费站(小唐良民一枚,所以要是经过收费站就会停下来交完钱再走)。

DY引擎果然是好东西,但是可惜引擎最多只能用K(0<=K<=30)次。

分析

这道题的难点主要在求出哪个点有收费站。

可以把题目分成两部分:

求出哪个点有收费站

这部分用到个很神奇的东西,差分约束系统

设\(s_{i}\)表示在中转点1~i有多少个收费站,

那么对于每个提示[u,v,t],

\(s_{v}-s_{u-1}>=c\),移项得\(s_{u-1}-s_{v}<=-c\)。

但这不足以求出所有的\(s\)值,那么注意隐藏条件:

\(s_{i}-s_{i-1}>=0\),移项得\(s_{i-1}-s_{i}<=0\)

\(s_{i}-s_{i-1}<=1\)

接着对于一条式子“a-b<=c”,给b向a连一条权值为c的有向边,搞一遍spfa就可以了(其中\(s_{n}=m\),显然嘛)

求最短路

先把原图分为k+1层,

搞一遍floyd,求出可以瞬移的路径,

每一层连一条可以瞬移的路径到下一层。

spfa完美收场。

#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const long long maxlongint=21474836470000;
using namespace std;
long long next[2000000],last[2000000],to[2000000],v[2000000],dis[2000000],d[5000000],f[400][400],re[60000][4];
long long a[400][400];
long long n,m,ans,k,l,e,tot;
bool bz[2000000];
long long bj(long long x,long long y,long long z)
{
next[++tot]=last[x];
last[x]=tot;
to[tot]=y;
v[tot]=z;
}
long long spfa(long long x,long long y)
{
memset(bz,true,sizeof(bz));
memset(dis,60,sizeof(dis));
long long head=0,tail=1,g;
dis[x]=y;
d[1]=x;
while(head<tail)
{
g=d[++head];
bz[g]=true;
for(long long i=last[g];i;i=next[i])
{
long long j=to[i];
if(dis[j]>dis[g]+v[i])
{
dis[j]=dis[g]+v[i];
if(bz[j])
{
bz[j]=false;
d[++tail]=j;
}
}
}
}
}
int main()
{
//第一部分
long long o;
scanf("%lld%lld%lld%lld%lld%lld",&n,&m,&e,&o,&l,&k);
memset(f,60,sizeof(f));
for(long long i=1;i<=e;i++)
{
long long x,y,z;
scanf("%lld%lld%lld",&x,&y,&z);
re[i][1]=x;
re[i][2]=y;
re[i][3]=z;
f[x][y]=min(z,f[x][y]);
f[y][x]=f[x][y];
}
for(long long i=1;i<=o;i++)
{
long long x,y,z;
scanf("%lld%lld%lld",&x,&y,&z);
bj(y,x-1,-z);
}
for(long long i=2;i<=n;i++)
{
bj(i,i-1,0);
bj(i-1,i,1);
}
spfa(n,m);
//第二部分
memset(last,0,sizeof(last));
tot=0;
for(long long i=1;i<=e;i++)
{
for(long long p=0;p<=k;p++)
{
bj(p*n+re[i][1],p*n+re[i][2],re[i][3]);
bj(p*n+re[i][2],p*n+re[i][1],re[i][3]);
}
}
for(long long i=1;i<=n;i++)
for(long long j=1;j<=n;j++)
{
for(long long p=1;p<=n;p++)
if(i!=j && j!=p && i!=p && dis[p]-dis[p-1]==0 && dis[p]<=m)
{
if(f[i][p]+f[p][j]<f[i][j])
f[i][j]=f[i][p]+f[p][j];
} }
for(long long i=1;i<=n;i++)
for(long long j=1;j<=n;j++)
if(i!=j && f[i][j]<=l)
{
for(long long p=0;p<=k-1;p++)
{
bj(p*n+i,(p+1)*n+j,0);
}
}
spfa(1,0);
ans=maxlongint;
for(long long i=0;i<=k;i++)
ans=min(dis[i*n+n],ans);
printf("%lld\n",ans);
}

【NOIP2013模拟】DY引擎的更多相关文章

  1. 【NOIP2013模拟】终极武器(经典分析+二分区间)

    No.2. [NOIP2013模拟]终极武器 题意: 给定你一些区间,然后让你找出\(1\sim 9\)中的等价类数字. 也就是说在任何一个区间里的任何一个数,把其中后\(k\)位中的某一位换成等价类 ...

  2. JZOJ 3493. 【NOIP2013模拟联考13】三角形

    3493. [NOIP2013模拟联考13]三角形(triangle) (File IO): input:triangle.in output:triangle.out Time Limits: 10 ...

  3. JZOJ 3487. 【NOIP2013模拟联考11】剑与魔法(dragons)

    3487. [NOIP2013模拟联考11]剑与魔法(dragons) (Standard IO) Time Limits: 1000 ms  Memory Limits: 131072 KB  De ...

  4. JZOJ 3470. 【NOIP2013模拟联考8】最短路(path)

    470. [NOIP2013模拟联考8]最短路(path) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  5. JZOJ 3388. 【NOIP2013模拟】绿豆蛙的归宿

    3388. [NOIP2013模拟]绿豆蛙的归宿 (Standard IO) Time Limits: 1000 ms  Memory Limits: 131072 KB  Detailed Limi ...

  6. JZOJ 3463. 【NOIP2013模拟联考5】军训

    3463. [NOIP2013模拟联考5]军训(training) (Standard IO) Time Limits: 2000 ms  Memory Limits: 262144 KB  Deta ...

  7. JZOJ 3462. 【NOIP2013模拟联考5】休息(rest)

    3462. [NOIP2013模拟联考5]休息(rest) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  8. JZOJ 3461. 【NOIP2013模拟联考5】小麦亩产一千八(kela)

    3461. [NOIP2013模拟联考5]小麦亩产一千八(kela) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Det ...

  9. JZOJ 3509. 【NOIP2013模拟11.5B组】倒霉的小C

    3509. [NOIP2013模拟11.5B组]倒霉的小C(beats) (File IO): input:beats.in output:beats.out Time Limits: 1000 ms ...

随机推荐

  1. 开发一个Flink应用

    步骤列表本次实战经历以下步骤: 创建应用:编码:构建:提交任务到Flink,验证功能: 环境信息Flink:1.7:Flink所在机器的操作系统:CentOS Linux release 7.5.18 ...

  2. 测开之路一百四十六:WTForms之表单应用

    WTForms主要是两个功能:1.生成HTML标签  2.对数据格式进行验证 官网:https://wtforms.readthedocs.io/en/stable/ 这篇介绍用wtform生成htm ...

  3. WIN10重启后,在任务栏下添加快捷工具栏消失问题修复

    WIN10重启后,在任务栏下添加快捷工具栏消失问题修复 可以在windows 设置 - - 设备 - - 输入 - - 高级键盘设置 - - 不要勾选 <使用桌面语言栏(如果可用 )>

  4. Eclipse 添加 UML Model插件

    1.下载安装 ModelGson 下载链接:https://pan.baidu.com/s/1smIZApv   密码:mu5l eclipse安装ModelGson(注意不用解压ModelGson, ...

  5. linux常用终端指令+如何用vim写一个c程序并运行

    在装好ubuntu之后今天学习了一些linux的一些基础知识: windows里面打开命令窗口是win+r,在linux系统里面,ctrl+alt+t打开终端,今天的一些指令都是围绕终端来说的 首先s ...

  6. python locust 进行压力测试

    最近公司项目周期比较赶, 项目是软硬结合,在缺少硬件的情况下,通过接口模拟设备上下架和购买情况,并进行压力测试, 本次主要使用三个接口 分别是3个场景: 生成商品IP, 对商品进行上架, 消费者购买商 ...

  7. IP子网的划分

    一.划分子网的具体步骤 已知192.168.1.0/24,划分8个子网(一个ip划分8个子网,即网络位不再是24位)1100 0000.1010 1000.0000 0001.0000 00001 . ...

  8. 从零构建vue项目(一)--搭建node环境,拉取项目模板

    本文是基于vuecli2搭建的项目. 1. 下载安装nodejs     地址:https://nodejs.org/en/download/ 选择安装版windows .msi, 不要选择压缩版 下 ...

  9. 利用coverage工具进行Python代码覆盖率测试

    Coverage是一种用于统计Python代码覆盖率的工具,通过它可以检测测试代码对被测代码的覆盖率情况. Coverage安装 1.安装命令:pip install coverage 2.查看cov ...

  10. c++ 加载库错误问题解决

    转载自:http://blog.csdn.net/sahusoft/article/details/7388617 一般我们在Linux下执行某些外部程序的时候可能会提示找不到共享库的错误, 比如: ...