题目描述 Description###

\(FYH\) 在 \(ns\) 星系迷路了,情急之下,他找到了你。现在,解救 \(FYH\) 的重任就落在了你的肩上了。

\(ns\) 星系有 \(n\) 颗星球,编号为 \(1\) 到 \(n\) 的整数。星球之间由 \(m\) 条单向的时空隧道相连。经过每个时空隧道要花费一定的时间。\(FYH\) 的飞船最多可以存储 \(max energy\) 的能量,经过有些时空隧道会损失能量,而其他的会增加能量。飞船不能通过损失能量数超过当前能量或者增加能量后飞船能量超过 \(max energy\) 的时空隧道。现在,\(FYH\) 的飞船在编号为 \(1\) 的星球,飞船剩余的能量为 \(max energy\) 的一半。你需要计算出到编号为 \(n\) 的星球的最短时间。

输入描述 Input Description###

第一行三个正整数 \(n\),\(m\) 和 \(max energy\)。

接下来 \(m\) 行,每行 3 个正整数 \(u\) ,\(v\) ,\(time\) 和 1 个整数 \(energy\) 。表示从编号为 \(u\) 的星球到编号为 \(v\) 的星球有一条时空隧道,经过这个隧道花费的时间为 \(time\) 。如果 \(energy\) 为正数,则表示通过会增加 \(energy\) 的能量,否则表示通过会损失 \(−energy\) 的能量。保证,1 ≤ u,v ≤ n,1 ≤ time ≤ 10 4 ,−100 ≤ energy ≤ 100。

每行两个数之间均用空格隔开。

输出描述 Output Description###

输出一行,一个正整数,表示到达的最短时间。数据保证有解。

样例输入 Sample Input###

4 6 4
1 4 100 0
1 2 5 -1
2 3 3 2
3 2 1 -1
3 4 5 -4
3 4 10 -3

样例输出 Sample Output###

17

数据范围及提示 Data Size & Hint###

\(n \leq 50, m \leq 2000 ,max energy \leq 50\)

之前的一些废话###

题解###

考虑到n很小,\(max energy\) 又不是很大,所以我们就可以设状态\(dp[i][j]\) 表示当前在i星球,有j能量的最短时间,然后把这些状态压成一些点,直接跑一个最短路即可。

代码###

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<cstring>
#include<cmath>
using namespace std;
typedef long long LL;
typedef pair<int,int> PII;
#define mem(a,b) memset(a,b,sizeof(a))
inline int read()
{
int x=0,f=1;char c=getchar();
while(!isdigit(c)){if(c=='-')f=-1;c=getchar();}
while(isdigit(c)){x=x*10+c-'0';c=getchar();}
return x*f;
}
const int maxm=200010,maxn=5010;
struct Edge
{
int u,v,w,power,next;
Edge() {}
Edge(int _1,int _2,int _3,int _4,int _5):u(_1),v(_2),w(_3),power(_4),next(_5) {}
}e[maxm],E[420];
int n,m,Energy,a,b,c,d,c1=-1,c2=-1,First[60],first[maxn],dis[maxn],ans=2147483647;
bool vis[maxn];
priority_queue <PII,vector<PII>,greater<PII> > Q;
int id(int x,int y){return (x-1)*(Energy+1)+y;}
void AddEdge(int a,int b,int c,int d){E[++c2]=Edge(a,b,c,d,First[a]);First[a]=c2;}
void addEdge(int a,int b,int c){e[++c1]=Edge(a,b,c,0,first[a]);first[a]=c1;}
void Dijkstra()
{
mem(dis,42);
dis[id(1,Energy/2)]=0;
Q.push(make_pair(0,id(1,Energy/2)));
while(Q.size())
{
int now=Q.top().second;Q.pop();
if(vis[now])continue;
vis[now]=1;
for(int i=first[now];i!=-1;i=e[i].next)
if(dis[e[i].v]>dis[now]+e[i].w)
{
dis[e[i].v]=dis[now]+e[i].w;
Q.push(make_pair(dis[e[i].v],e[i].v));
}
}
for(int i=0;i<=Energy;i++)ans=min(ans,dis[id(n,i)]);
return;
}
int main()
{
freopen("star.in","r",stdin);
freopen("star.out","w",stdout);
mem(first,-1);mem(First,-1);
n=read();m=read();Energy=read();
for(int i=1;i<=m;i++)a=read(),b=read(),c=read(),d=read(),AddEdge(a,b,c,d);
for(int k=1;k<=n;k++)
for(int j=0;j<=Energy;j++)
for(int i=First[k];i!=-1;i=E[i].next)
if(j+E[i].power<=Energy && j+E[i].power>=0)addEdge(id(k,j),id(E[i].v,j+E[i].power),E[i].w);
Dijkstra();
printf("%d\n",ans);
return 0;
}

总结###

属于套路题。

NOIP模拟赛 迷路的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  6. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  7. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  8. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

  9. CH Round #52 - Thinking Bear #1 (NOIP模拟赛)

    A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...

随机推荐

  1. poj 2456 Aggressive cows 二分 题解《挑战程序设计竞赛》

    地址 http://poj.org/problem?id=2456 解法 使用二分逐个尝试间隔距离 能否满足要求 检验是否满足要求的函数 使用的思想是贪心 第一个点放一头牛 后面大于等于尝试的距离才放 ...

  2. Java编译器的2点优化

    优化1 对于byte/short/char三种类型来说,如果右侧赋值的数值没有超过范围,那么javac编译器将会自动隐含地为我们补上一个(byte)(short)(char). 如果没有超过左侧的范围 ...

  3. 第05组 Alpha冲刺(2/4)

    第05组 Alpha冲刺(2/4) 队名:天码行空 组长博客连接 作业博客连接 团队燃尽图(共享): GitHub当日代码/文档签入记录展示(共享): 组员情况: 组员1:卢欢(组长) 过去两天完成了 ...

  4. WPF 动态生成对象属性 (dynamic)

    原文:WPF 动态生成对象属性 (dynamic) 项目中列行的数据 都需要动态生成 所以考虑到对象绑定  可需要一个动态生成属性的意思 缺点 加载速度会慢 很明显的慢 解决办法 尽量减轻动态属性的量 ...

  5. 关于group by的用法 原理

    转载: https://blog.csdn.net/u014717572/article/details/80687042. 写在前面的话:用了好久group by,今天早上一觉醒来,突然感觉grou ...

  6. Codeforces Round #599 (Div. 2) B2. Character Swap (Hard Version) 构造

    B2. Character Swap (Hard Version) This problem is different from the easy version. In this version U ...

  7. 你想了解的「SpringCloud」都在这里

    前言: 之前我们已经了解了「什么是微服务?」,现在我们开始了解「微服务」关键字下比较热门的「Spring Cloud」... 一.传统架构发展史 部分引用自:从架构演进的角度聊聊Spring Clou ...

  8. 再一次生产 CPU 高负载排查实践

    前言 前几日早上打开邮箱收到一封监控报警邮件:某某 ip 服务器 CPU 负载较高,请研发尽快排查解决,发送时间正好是凌晨. 其实早在去年我也处理过类似的问题,并记录下来:<一次生产 CPU 1 ...

  9. .NET Core 内置的 System.Text.Json 使用注意

    System.Text.Json 是 .NET Core 3.0 新引入的高性能 json 解析.序列化.反序列化类库,武功高强,但毕竟初入江湖,炉火还没纯青,使用时需要注意,以下是我们在实现使用中遇 ...

  10. java(二)变量

    基础数据类型: 数值型:整型(byte.short.int.long).浮点型(float.double)java各整数类型有固定的表数范围和字段长度,不受具体os的影响,以保持java的可移植性:j ...