【LibreOJ】#539. 「LibreOJ NOIP Round #1」旅游路线
【题意】给定正边权有向图,车油量上限C,每个点可以花费pi加油至min(C,ci),走一条边油-1,T次询问s点出发带钱q,旅行路程至少为d的最多剩余钱数。
n<=100,m<=1000,C<=10^5,q<=n^2。
【算法】动态规划
【题解】官方题解
虽然不是DAG,但是由于q很小的特点,将q加入状态就满足DP的无后效性了。
令f[i][q]表示当前在i点并在i点加油,加油前钱数为q的最大路程。(q<pi时,f[i][q]=0)
假设下一加油点为j,转移方程:f[i][q]=max{f[j][q-pi]+w(i,j,ci)},其中w(i,j,c)表示i点到j点,油量为c的最大路程。(ci=min(ci,C))
现在主要问题是预处理w(i,j,ci),发现每走一条边c只会减少1,符合倍增变化规则一致的特点,考虑图上倍增。
虽然不是DAG,但是c加入状态就满足DP的无后效性了。
g(i,j,k)表示i点到j点,油量为2^k的最大路程,显然g(i,j,k)=max{g(i,x,k-1)+g(x,j,k-1)},x是中转点。
对于w(i,j,ci),将ci拆分二进制,每次枚举x作为中转点后直接取倍增数组g计算答案。
【倍增的思想是很经典的,将需要的ci拆分二进制后将1的位用倍增数组堆起来。但是应用到图上每次就都需要遍历全图作为可能的中转点,最后找到最优答案。】
最后得到了f[i][q],对每个询问在f[s]上二分到第一个大于等于d的f[s][q],q就是答案。
复杂度O(n^4+n^3*log k+T*log n^2),瓶颈复杂度O(n^4)。(n^4过100……)
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cctype>
using namespace std;
int read(){
char c;int s=,t=;
while(!isdigit(c=getchar()))if(c=='-')t=-;
do{s=s*+c-'';}while(isdigit(c=getchar()));
return s*t;
}
const int maxn=,maxm=,maxk=,inf=0x3f3f3f3f;
int n,m,C,T,tot;
int g[maxn][maxn][maxk],p[maxn],c[maxn],A[maxn],B[maxn],w[maxn][maxn],f[maxn][maxn*maxn];
void cmax(int &a,int b){if(b>a)a=b;}
int main(){
n=read();m=read();C=read();T=read();
for(int i=;i<=n;i++)for(int j=;j<=n;j++)for(int k=;k<=;k++)g[i][j][k]=-inf;
for(int i=;i<=n;i++)p[i]=read(),c[i]=min(C,read()),g[i][i][]=;
for(int i=;i<=m;i++){
int u=read(),v=read(),w=read();
g[u][v][]=w;
}
for(int k=;k<=;k++)
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
for(int x=;x<=n;x++)cmax(g[i][j][k],g[i][x][k-]+g[x][j][k-]);
for(int i=;i<=n;i++){
for(int j=;j<=n;j++)A[j]=-inf;A[i]=;
for(int k=;k<=;k++)if((c[i]>>k)&){
for(int j=;j<=n;j++){
B[j]=-inf;
for(int x=;x<=n;x++)cmax(B[j],A[x]+g[x][j][k]);
}
for(int j=;j<=n;j++)A[j]=B[j];
}
for(int j=;j<=n;j++)w[i][j]=A[j];
}
for(int q=;q<=n*n;q++)
for(int x=;x<=n;x++)if(q>=p[x])
for(int y=;y<=n;y++)cmax(f[x][q],f[y][q-p[x]]+w[x][y]);
while(T--){
int s=read(),q=read(),d=read();
int pl=lower_bound(f[s],f[s]+n*n+,d)-f[s];
if(pl>q)printf("-1\n");else printf("%d\n",q-pl);
}
return ;
}
【LibreOJ】#539. 「LibreOJ NOIP Round #1」旅游路线的更多相关文章
- LibreOJ #539. 「LibreOJ NOIP Round #1」旅游路线(倍增+二分)
哎一开始看错题了啊T T...最近状态一直不对...最近很多傻逼题都不会写了T T 考虑距离较大肯定不能塞进状态...钱数<=n^2能够承受, 油量再塞就不行了...显然可以预处理出点i到j走c ...
- LOJ#539. 「LibreOJ NOIP Round #1」旅游路线
n<=100,m<=1000的图,在此图上用油箱容量C<=1e5的车来旅行,旅行时,走一条边会耗一单伟油,在点i时,若油量<ci,则可以把油以pi的价格补到ci,pi<= ...
- LOJ #539. 「LibreOJ NOIP Round #1」旅游路线 倍增floyd + 思维
考试的时候是这么想的: 求出每一个点花掉 $i$ 的花费向其他点尽可能走的最长距离,然后二分这个花费,找到第一个大于 $d$ 的就输出$.$然而,我这个记忆化搜索 $TLE$ 的很惨$.$这里讲一下正 ...
- 「LOJ 539」「LibreOJ NOIP Round #1」旅游路线
description 题面较长,这里给出题目链接 solution 考虑预处理出\(f[i][j]\)表示在第\(i\)个点加满油后,从第\(i\)个点出发,至多消耗\(j\)元钱走过的最大路程,那 ...
- LibreOj #539. 「LibreOJ NOIP Round #1」旅游路线
题目链接 做完这道题,我深知当一个问题复杂度过高的时候,把一些可以分离的操作都分散开,可以大幅度降低复杂度..... 发现无论有多少钱,每到一个点后扩展到的距离被限制在 \(min(C, c[i])\ ...
- 「LibreOJ NOIP Round #1」旅游路线
Description T 城是一个旅游城市,具有 nnn 个景点和 mmm 条道路,所有景点编号为 1,2,...,n1,2,...,n1,2,...,n.每条道路连接这 nnn 个景区中的某两个景 ...
- LibreOJ #517. 「LibreOJ β Round #2」计算几何瞎暴力
二次联通门 : LibreOJ #517. 「LibreOJ β Round #2」计算几何瞎暴力 /* LibreOJ #517. 「LibreOJ β Round #2」计算几何瞎暴力 叫做计算几 ...
- LibreOJ #528. 「LibreOJ β Round #4」求和
二次联通门 : LibreOJ #528. 「LibreOJ β Round #4」求和 /* LibreOJ #528. 「LibreOJ β Round #4」求和 题目要求的是有多少对数满足他们 ...
- LibreOJ #527. 「LibreOJ β Round #4」框架
二次联通门 : LibreOJ #527. 「LibreOJ β Round #4」框架 /* LibreOJ #527. 「LibreOJ β Round #4」框架 %% xxy dalao 对于 ...
随机推荐
- 关于JS里面写JAVA代码的问题
最近做项目需要在JS脚本里面调用一个JAVA的函数得到数据,在网上查了很久,发现JS脚本里面不能写JAVA函数.只能把JS脚本里面的代码写进JSP文件里面的<script>标签内,然后写J ...
- bzoj4031-小Z的房间
题目 给一个\(n\*m\)的矩阵,每个点可能为"."或"*",有多少种方法把矩阵中的点全部连接起来,并且每两个点之间只有一条路径. 分析 题目所求的是一个矩阵 ...
- Android UI设计的基本元素有哪些
在android app开发如火如荼的今天,如何让自己的App受人欢迎.如何增加app的下载量和使用量....成为很多android应用开发前,必须讨论的问题.而ui设计则是提升客户视觉体验度.提升下 ...
- hdu 2962 Trucking (最短路径)
Trucking Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- Square Root of Permutation - CF612E
Description A permutation of length n is an array containing each integer from 1 to n exactly once. ...
- Oracle 验证A表的2个字段组合不在B表2个字段组合里的数据
select id, name from TAB_A t where not exists (select 1 from TAB_B t1 where t.id = t1.id and t.name ...
- 具体数学二项式至生成函数章-----致敬Kunth
关于标题取得这么奇怪.因为在具体数学中.这两章是分开叙述的.并且分别叙述得淋漓尽致! 我只参悟其中关于生成函数的一小部分内容(暂时于我够用了.) 提二项式系数之前不得不提组合数.以往在高中用的是符号C ...
- BZOJ1597 & 洛谷2900:[USACO2008 MAR]Land Acquisition 土地购买——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=1597 https://www.luogu.org/problemnew/show/P2900 约翰准 ...
- android eclipse ndk使用记录
为方便开发jni程序,android提供了ndk包来简化开发过程,避免开发人员下载完整的平台代码,并且可以在windows环境下集成到eclipse里面,大大加快了开发速度.这里记录下一个简单例子. ...
- BZOJ Lydsy5月月赛 ADG题解
题目链接 BZOJ5月月赛 题解 好弱啊QAQ只写出三题 A 判断多干个数乘积是否是某个数的倍数有很多方法,比较常用的是取模,但这里并不适用,因为模数不定 会发现数都比较小,所以我们可以考虑分解质因子 ...