CF553E Kyoya and Train
Kyoya and Train
一个有\(n\)个节点\(m\)条边的有向图,每条边连接了\(a_i\)和\(b_i\),花费为\(c_i\)。
每次经过某一条边就要花费该边的\(c_i\)。
第\(i\)条边耗时为\(j\)的概率为\(p_{i,j}\)。
现在你从\(1\)开始走到\(n\),如果你在\(t\)单位时间内(包括\(t\))到了\(n\),不需要任何额外花费,否则你要额外花费\(x\)。
问你在最优策略下的期望花费最小为多少。(注意你每走一步都会根据当前情况制定最好的下一步)
\(n\leq 50 ,m \leq 100, t\leq 20000, x\leq 10^6\)
毛啸论文

看别人的代码,我学会了怎么用线性的空间预处理单位根。
\]
而\(\frac{lim}{2step}\times i < \frac{lim}{2},i\in [0,step)\),所以预处理\(\omega^{\frac{2\pi}{lim}}\)的次幂即可。
co double pi=acos(-1);
struct node {double x,y;};
il node operator+(co node&a,co node&b){
	return (node){a.x+b.x,a.y+b.y};
}
il node operator-(co node&a,co node&b){
	return (node){a.x-b.x,a.y-b.y};
}
il node operator*(co node&a,co node&b){
	return (node){a.x*b.x-a.y*b.y,a.x*b.y+a.y*b.x};
}
co int N=55,M=105,T=20005,S=1<<15;
int n,m,t,punish;
int a[M],b[M],c[M],dis[N][N];
double dp[N][T],sum[M][T],p[M][T];
int rev[S];
node w[S],A[S],B[S];
void fourier_trans(node a[],int lim){
	for(int i=0;i<lim;++i)
		if(i<rev[i]) swap(a[i],a[rev[i]]);
	for(int step=1;step<lim;step<<=1){
		int quot=lim/(step<<1);
		for(int i=0;i<lim;i+=step<<1){
			int j=i+step;
			for(int k=0;k<step;++k){
				node t=w[quot*k]*a[j+k];
				a[j+k]=a[i+k]-t,a[i+k]=a[i+k]+t;
			}
		}
	}
}
void solve(int l,int r){
	if(l==r){
		for(int e=1;e<=m;++e)
			dp[a[e]][l]=min(dp[a[e]][l],sum[e][l]+c[e]);
		return;
	}
	int mid=(l+r)>>1;
	solve(mid+1,r);
	int len=int(ceil(log2(r-mid+r-l-1))),lim=1<<len;
	for(int i=0;i<lim;++i){
		rev[i]=rev[i>>1]>>1|(i&1)<<(len-1);
		w[i]=(node){cos(i*2*pi/lim),sin(i*2*pi/lim)};
	}
	for(int e=1;e<=m;++e){
		for(int i=0;i<lim;++i)
			A[i]=B[i]=(node){0,0};
		for(int i=mid+1;i<=r;++i)
			A[i-mid-1]=(node){dp[b[e]][i],0};
		for(int i=1;i<=r-l;++i)
			B[r-l-i]=(node){p[e][i],0};
		fourier_trans(A,lim),fourier_trans(B,lim);
		for(int i=0;i<lim;++i){
			A[i]=A[i]*B[i];
			w[i].y=-w[i].y;
		}
		fourier_trans(A,lim);
		for(int i=0;i<lim;++i){
			A[i].x/=lim;
			w[i].y=-w[i].y;
		}
		for(int i=l;i<=mid;++i)
			sum[e][i]+=A[i-mid-1+r-l].x;
	}
	solve(l,mid);
}
int main(){
	scanf("%d%d%d%d",&n,&m,&t,&punish);
	for(int i=1;i<=n;++i)
		for(int j=1;j<=n;++j)
			dis[i][j]=i==j?0:1e9;
	for(int i=1;i<=m;++i){
		scanf("%d%d%d",a+i,b+i,c+i);
		dis[a[i]][b[i]]=min(dis[a[i]][b[i]],c[i]);
		for(int j=1;j<=t;++j)
			scanf("%lf",p[i]+j),p[i][j]/=100000;
	}
	for(int k=1;k<=n;++k)
		for(int i=1;i<=n;++i)
			for(int j=1;j<=n;++j)
				dis[i][j]=min(dis[i][j],dis[i][k]+dis[k][j]);
	for(int i=0;i<N;++i)
		for(int j=0;j<T;++j)
			dp[i][j]=1e9;
	for(int i=1;i<=n;++i) dp[i][t+1]=punish+dis[i][n];
	for(int i=0;i<=t;++i) dp[n][i]=0;
	for(int e=1;e<=m;++e){
		double P=0;
		for(int i=1;i<=t;++i){
			P+=p[e][t+1-i];
			sum[e][i]=P*dp[b[e]][t+1];
		}
	}
	solve(0,t);
	printf("%lf\n",dp[1][0]);
	return 0;
}
CF553E Kyoya and Train的更多相关文章
- 【CF553E】Kyoya and Train 最短路+cdq分治+FFT
		[CF553E]Kyoya and Train 题意:有一张$n$个点到$m$条边的有向图,经过第i条边要花$c_i$元钱,经过第i条边有$p_{i,k}$的概率要耗时k分钟.你想从1走到n,但是如果 ... 
- [Codeforces 553E]Kyoya and Train(期望DP+Floyd+分治FFT)
		[Codeforces 553E]Kyoya and Train(期望DP+Floyd+分治FFT) 题面 给出一个\(n\)个点\(m\)条边的有向图(可能有环),走每条边需要支付一个价格\(c_i ... 
- ●codeforces 553E Kyoya and Train
		题链: http://codeforces.com/problemset/problem/623/E 题解: FFT,DP 题意: 一个有向图,给出每条边的起点u,终点v,费用c,以及花费每种时间的概 ... 
- CodeForces 553E Kyoya and Train 动态规划 多项式 FFT 分治
		原文链接http://www.cnblogs.com/zhouzhendong/p/8847145.html 题目传送门 - CodeForces 553E 题意 一个有$n$个节点$m$条边的有向图 ... 
- 【codeforces 553E】 Kyoya and Train
		http://codeforces.com/problemset/problem/553/E (题目链接) 艹尼玛,CF还卡劳资常数w(゚Д゚)w!!系统complex被卡TLE了T_T,劳资写了一天 ... 
- CF 553E Kyoya and Train
		题目分析 期望\(\text{dp}\). 设\(f_{i,j}\)表示在第\(j\)个时刻从\(i\)点出发,到达终点的期望花费. 有转移方程: \[ f_{x,t}=\min_{(x,y)\in ... 
- Codeforces 553E Kyoya and Train
		题目大意 链接:CF533E 给一张\(n\)个点,\(m\)条边的图,起点\(1\)终点\(n\),如果不能在\(T\)的时间内到达则需支付\(X\)的代价. 走每条边都会支付一定代价,经过一条边\ ... 
- FFT/NTT复习笔记&多项式&生成函数学习笔记Ⅱ
		因为垃圾电脑太卡了就重开了一个... 前传:多项式Ⅰ u1s1 我预感还会有Ⅲ 多项式基础操作: 例题: 26. CF438E The Child and Binary Tree 感觉这题作为第一题还 ... 
- 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/常用套路【入门】
		原文链接https://www.cnblogs.com/zhouzhendong/p/Fast-Fourier-Transform.html 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/ ... 
随机推荐
- KAFA架构及其基本概念
			1.目标 - KAFA价格 在我们上一篇Kafka教程中,我们讨论了Kafka用例和应用程序.今天,在这个Kafka教程中,我们将讨论Kafka Architecture.在这篇Kafka Archi ... 
- C++ 读取一个文件下所有文件的文件名
			Windows: #include<iostream> #include<string> #include <io.h> void readFileNameInDi ... 
- mongdb基本使用
			mongodb创建用户,设置密码 参考:https://www.jianshu.com/p/237a0c5ad9fa MongoDB内置的数据库角色有: 1. 数据库用户角色:read.readWri ... 
- [国家集训队] JZPKIL
			题目链接 洛谷:https://www.luogu.org/problemnew/show/P4464 Solution 这题是真的毒....数论大杂烩,窝断断续续写了两天. 众所周知: \[ {\r ... 
- 创建job,delete定时清理数据
			Job定时删除数据 需求:对一个表,每天删除一月前的历史数据 思路 .编写SQL,删除一月前的历史数据,使用函数取值 .测试JOB创建,查询,维护,管理 .测试布置job,满足效果 ***测试数据准备 ... 
- CSS3 @font-face 规则
			指定名为"myFirstFont"的字体,并指定在哪里可以找到它的URL: @font-face { font-family: myFirstFont; src: url('San ... 
- Docker安装带中文全文搜索插件zhparser的Postgresql数据库
			上一篇讲了在已经安装了PG数据库的情况下,安装全文搜索插件zhparser遇到的问题.在一个全新的环境中安装带有全文搜索插件zhparser的PG数据库,可以使用已经做好的Docker镜像,在安装的过 ... 
- ADO.Net和SqlHelper封装
			1.什么是ADO.Net 简单来讲,ADO.NET是用于和数据源打交道的.Net结束,是一组向.NET程序员公开数据访问服务的类 2.ADO.NET的组成部分和对象模型 (1)ADO.NET的两个 ... 
- 1+X证书学习日志——定位
			## 静态定位: position:static; 默认值,指定left/right/top/bottom/ 没有作用. pos ... 
- 过渡属性transition
			过渡属性:使元素变化过程可见 transition: all 1s;元素所有变化过程都可见 transition: 1s;元素所有变化过程都可见 transition: 指定属性 2s 1s;指定属性 ... 
