BZOJ4386: [POI2015]Wycieczki
来源:互联网 发布:淘宝联盟 退运费 福袋 编辑:程序博客网 时间:2024/04/18 23:06
题目大意:给定一张n个点m条边的带权有向图,每条边的边权只可能是1,2,3中的一种,输出k段路径,没有输出-1
一眼矩阵乘法嘛,弱智题O((3*N)^3*log(INF)*log(K))
然后手贱搜了一下题解,把我惊到了...
首先这个时间复杂度是过不了的,也就是说不能二分然后快速幂直接判
应该先预处理出来所有2的k次幂,然后就像LCA一样,这样可以一个log搞出来
其次是.....
这题会爆longlong,所以做矩阵乘法的时候需要判断爆没爆,如果出现负数了,说明这个结果一定很大,拿个bool记一下就好了
太坑了!
代码Orz Claris
#include<cstdio>#define N 121typedef long long ll;int n,m,B,T,i,j,k,x,y,z,f[N][3],v[N];ll K,a[62][N][N],b[N][N],c[N][N],ans;void mul(ll a[][N],ll b[][N],ll c[][N]){ for(int i=0;i<T;i++)for(int j=0;j<T;j++){ c[i][j]=0; for(int k=0;k<T;k++)if(a[i][k]&&b[k][j]){ if(a[i][k]<0||b[k][j]<0){c[i][j]=-1;break;} if(a[i][k]>K/b[k][j]){c[i][j]=-1;break;} c[i][j]+=a[i][k]*b[k][j]; if(c[i][j]>K){c[i][j]=-1;break;} } }}bool check(){ ll t=0; for(int i=0;i<T;i++)if(c[0][i]&&v[i]){ if(c[0][i]<0)return 0; if(c[0][i]>K/v[i])return 0; t+=c[0][i]*v[i]; if(t>K)return 0; } return t<K;}int main(){ scanf("%d%d%lld",&n,&m,&K); for(T=i=1;i<=n;i++)for(j=0;j<3;j++)f[i][j]=T++; a[0][0][0]++; for(i=1;i<=n;i++){ for(j=0;j<2;j++)a[0][f[i][j]][f[i][j+1]]++; a[0][0][f[i][0]]++; } while(m--)scanf("%d%d%d",&x,&y,&z),a[0][f[y][z-1]][f[x][0]]++,v[f[y][z-1]]++; for(B=0;(1LL<<B)<=K*3;B++); for(i=1;i<B;i++)mul(a[i-1],a[i-1],a[i]); for(i=0;i<T;i++)b[i][i]=1; for(i=B-1;~i;i--){ mul(b,a[i],c); if(check())for(ans|=1LL<<i,j=0;j<T;j++)for(k=0;k<T;k++)b[j][k]=c[j][k]; } ans++; if(ans>K*3)ans=-1; return printf("%lld",ans),0;}
0 0
- BZOJ4386: [POI2015]Wycieczki
- BZOJ4386[POI2015] Wycieczki
- BZOJ4386: [POI2015]Wycieczki
- bzoj 4386: [POI2015]Wycieczki 矩阵乘法&倍增
- POI2015 题解
- bzoj 3747: [POI2015]Kinoman
- bzoj3747【POI2015】Kinoman
- [BZOJ3747] [POI2015]Kinoman
- 【POI2015】【BZOJ4378】Logistyka
- BZOJ 3747: [POI2015]Kinoman
- BZOJ 3748: [POI2015]Kwadraty
- BZOJ4378: [POI2015]Logistyka
- BZOJ4379: [POI2015]Modernizacja autostrady
- BZOJ4381: [POI2015]Odwiedziny
- BZOJ4383: [POI2015]Pustynia
- 【bzoj4378】[POI2015]Logistyka
- 【bzoj4380】[POI2015]Myjnie
- [bzoj4378][POI2015]Logistyka
- Android 定义全局LOG打印日志,并显示调用者相关信息
- uva191 Intersection(线段之间相交)
- 直接量
- 监听通知,在程序退出前要移除
- 字符串排序 nyoj 1149
- BZOJ4386: [POI2015]Wycieczki
- SDWebImage的细节问题
- 讲一个数组内的对象属性保存到另一个数组
- myeclipse中Could not find the main class: org.apache.catalina.startup.Boostrap. Program will exit
- Js apply call方法
- 2016-05-09 随感,生活还是眼前的苟且
- Html5——本地数据库
- 错误调试与异常处理 错 误 类 型
- 获取一个按钮数组内的所有按钮的标题