对于每组询问,spfa求出f[i][j]表示从S出发,经过j条x边到达i的最短路。

若f[T][i]都为inf,则无解。

若f[T][0]为inf,则有无穷个解。

否则可以看作若干条直线,$O(n)$求出凸壳。

算出相邻两条直线交点横坐标并取下整,若刚好为整数则-1,设b[i]为i与i+1的交点的横坐标。

则第i(1<=i<t)段的贡献为首项为f(b[i-1]+1),末项为f(b[i])的等差数列。

最后一段的斜率为0,所以贡献为f[T][0]。

#include<cstdio>
typedef long long ll;
const int N=510,M=10010,inf=~0U>>1;
int n,m,i,j,x,y,z,S,T,g[N],v[M],w[M],nxt[M],ed,f[N][N],in[N][N],q[1000000][2];
int h,t,a[N],b[N],cnt;ll sum;
inline void read(int&a){
char c;
while(!((((c=getchar())>='0')&&(c<='9'))||(c=='x')));
if(c=='x'){a=0;return;}
a=c-'0';
while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';
}
inline void addedge(int x,int y,int z){v[++ed]=y;w[ed]=z;nxt[ed]=g[x];g[x]=ed;}
inline void add(int x,int y,int z){
if(y>=n)return;
if(f[x][y]<=z)return;
f[x][y]=z;
if(!in[x][y])in[x][y]=1,q[++t][0]=x,q[t][1]=y;
}
inline double cross(int x,int y){return (double)(f[T][x]-f[T][y])/(double)(y-x);}
inline int crossi(int x,int y){
int a=f[T][y]-f[T][x],b=x-y;
if(a<=0)return 0;
return(a-1)/b;
}
inline void cal(int k,int b,int l,int r){
if(l<1)l=1;
if(l>r)return;
cnt+=r-l+1;
sum+=((ll)(l+r)*k+2LL*b)*(r-l+1)/2;
}
int main(){
read(n),read(m);
while(m--)read(x),read(y),read(z),addedge(x,y,z);
read(m);
while(m--){
read(S),read(T);
for(i=1;i<=n;i++)for(j=0;j<n;j++)f[i][j]=inf;
h=1,t=0,add(S,0,0);
while(h<=t){
x=q[h][0],y=q[h++][1],in[x][y]=0;
for(i=g[x];i;i=nxt[i])add(v[i],y+(w[i]==0),f[x][y]+w[i]);
}
for(j=0;j<n;j++)if(f[T][j]<inf)break;
if(j==n){puts("0 0");continue;}
if(f[T][0]==inf){puts("inf");continue;}
for(t=0,i=n-1;~i;i--)if(f[T][i]<inf){
while(t>1&&cross(a[t-1],a[t])>=cross(a[t],i))t--;
a[++t]=i;
}
cnt=1,sum=f[T][0];
for(i=1;i<t;i++)cal(a[i],f[T][a[i]],b[i-1]+1,b[i]=crossi(a[i],a[i+1]));
printf("%d %lld\n",cnt,sum);
}
return 0;
}

  

BZOJ3482 : [COCI2013]hiperprostor的更多相关文章

  1. 【BZOJ 3482】 3482: [COCI2013]hiperprostor (dij+凸包)

    3482: [COCI2013]hiperprostor Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 277  Solved: 81 Descrip ...

  2. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  3. [COCI2013]DLAKAVAC

    [COCI2013]DLAKAVAC 题目大意: 有一个长度为\(m(m\le1500)\)的\(01\)串\(A\),进行\(k(k\le10^{18})\)次操作.一次操作完的串中若\(A_i=1 ...

  4. 【JZOJ3238】【BZOJ3482】超空间旅行

    description 在遥远的未来,行星之间的食品运输将依靠单向的贸易路线.每条路径直接连接两个行星,且其运输时间是已知的. 贸易商协会打算利用一项最近发现的新技术--超空间旅行,以增加一些新的航线 ...

随机推荐

  1. gem install factory_girl

    文章是从个人博客转过来的,  可以直接访问 iwangzheng.com https://github.com/thoughtbot/factory_girl https://github.com/t ...

  2. 极客教学:如何使用树莓派击落&劫持无人机

    本教程的目的是帮助大家理解如何研究未受保护的无线通信的安全风险所在,同时我们希望大家不要对技术进行滥用.我们这里采用的例子是一个流行的无人机模型:Parrot AR.Drone 2.0. 四轴无人机能 ...

  3. DCMTK开源库的学习笔记4:利用ini配置文件对dcm影像进行归档

    转:http://blog.csdn.net/zssureqh/article/details/8846337 背景介绍: 医学影像PACS工作站的服务端需要对大量的dcm文件进行归档,写入数据库处理 ...

  4. mysql如何设置密码

    1.用root 进入mysql后mysql>set password =password('你的密码');mysql>flush privileges;2.使用GRANT语句 mysql& ...

  5. 在CI中集成phpmailer,方便使用SMTP发送邮件

    直接使用phpmailer的话,有时候不是很方便,特别你的很多功能都是基于CI完成的时候,要相互依赖就不方便了,所以在想,那是否可以将phpmailer集成到CI中呢,像使用email类这样使用他,功 ...

  6. Datasets for Data Mining and Data Science

    https://github.com/mattbane/RecommenderSystem http://grouplens.org/datasets/movielens/ KDDCUP-2012官网 ...

  7. 要“jquery”ScriptResourceMapping。请添加一个名为 jquery (区分大小写)的 ScriptResourceMapping。”的解决办法。

    1.在网站根目录下新建一scripts文件夹,向里边添加jquery-1.7.2.min.js和jquery-1.7.2.js(可根据自己需要使用不同的版本),      2.在根目录下添加全局应用程 ...

  8. 在SharePoint 2010 母版页里添加自定义用户控件

    在SharePoint 2010 母版页里添加自定义用户控件(译) 使用自定义用户控件的好处: 1.容易部署:2.易于控制显示或隐藏. (在使用的过程中)可能要面对的问题是:如何在用户控件里使用Sha ...

  9. Java for LeetCode 033 Search in Rotated Sorted Array

    Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...

  10. 【JAVA、C++】LeetCode 014 Longest Common Prefix

    Write a function to find the longest common prefix string amongst an array of strings. 解题思路: 老实遍历即可, ...