【BZOJ 3482】 3482: [COCI2013]hiperprostor (dij+凸包)
3482: [COCI2013]hiperprostor
Time Limit: 20 Sec Memory Limit: 256 MB
Submit: 277 Solved: 81Description
在遥远的未来,行星之间的食品运输将依靠单向的贸易路线。每条路径直接连接两个行星,且其运输时间是已知的。贸易商协会打算利用一项最近发现的新技术——超空间旅行,以增加一些新的航线。通过超空间旅行的航线也是单向的。由于该项技术仍处于试验阶段,超空间旅行的时间目前是未知的,但它不取决于行星之间的距离,所以每个超空间旅行的路线将花费等量的时间。下图是三个相互联通的行星及其运输时间的例子。行星使用正整数标号,超空间旅行时间记为“x”(图片对应第输入样例):过境的时间以天计,并且始终是一个正整数。贸易商协会希望对引进新航线的后果进行分析:对于某两个行星A和B,他们想知道对于任意的x,从A到B的最短路径的总中转时间的所有可能的值。例如,在上述情况中,从星球2到星球1的最短路径所需时间可以取值5(如果x≥5),4,3,2,或1天(如果x<5)Input
输入的第一行包含两个整数P和R,分别代表行星的数目和航线数量,1≤P≤500,0≤R≤10000。接下来的R条航线路径包含两或三个整数:行星标号C和D(1≤C,D≤P,C≠D),和T,从C到D的旅行时间。对于传统的路径,T是一个整数(1≤T≤1000000),超空间航线中,T是字符“x”。 可以存在多行有两个相同的行星。下面的行中包含的整数Q(1≤Q≤10),表示查询的数量。以下Q行包含两个整数星球标号(A和B,A≠B),为贸易商协会的查询:“从A到B的最短路径时间的可能值是什么?Output
输出必须包含q行,每行??一个查询。每一行都必须包含两个整数:不同的可能值的数目和它们的总和。如果不同的可能值的数目是无限的,该行只输出“inf”。如果没有从A到B的路径,不同的可能值的数目及它们的总和都是0。Sample Input
4 4
1 2 x
2 3 x
3 4 x
1 4 8
3
2 1
1 3
1 4Sample Output
0 0
inf
3 17HINT
2016.6.15新加数据一组,未重测
Source
【分析】
f[i][j]表示走到i,走了j条x边,最短路。【好像spfa会被卡,我就打了dij
【dij的比较没有打return 调了半天哭死。。。
若f[i][j]全是INF 就是无解
若f[i][0]是INF 就是无穷解
然后其他的,得到i,f[i][ed],写成直线y=i*x+f[i][ed],维护一个凸包。
他们中间点的个数和值是等差数列,直接求和。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
using namespace std;
#define Maxn 510
#define Maxm 10010
#define LL long long
#define INF 0x7fffffff int n,m; int read()
{
char ch;
while(!(((ch=getchar())>=''&&ch<='')||(ch=='x')));
if(ch=='x') return ;
int x=ch-'';
while(((ch=getchar())>='')&&(ch<='')) x=x*+ch-'';
return x;
} struct node
{
int x,y,next,c;
}t[Maxm*];
int len,first[Maxn]; void ins(int x,int y,int c)
{
t[++len].x=x;t[len].y=y;t[len].c=c;
t[len].next=first[x];first[x]=len;
} struct hp
{
int x,y,dis;
friend bool operator < (hp x,hp y)
{
return x.dis>y.dis;
}
}; int f[Maxn][Maxn];
priority_queue<hp> q;
void dij(int st)
{
hp nw;nw.dis=;nw.x=st;nw.y=;
q.push(nw);f[st][]=;
while(!q.empty())
{
nw=q.top();q.pop();
if(nw.dis>f[nw.x][nw.y]) continue;
int x=nw.x;
hp now;
for(int i=first[x];i;i=t[i].next)
{
int y=t[i].y;
if(t[i].c==)
{
if(nw.y==n) continue;
now.x=y;now.y=nw.y+;now.dis=nw.dis;
if(f[now.x][now.y]>f[nw.x][nw.y])
{
f[now.x][now.y]=f[nw.x][nw.y];
q.push(now);
}
}
else
{
now.x=y;now.y=nw.y;now.dis=f[nw.x][nw.y]+t[i].c;
if(f[now.x][now.y]>f[nw.x][nw.y]+t[i].c)
{
f[now.x][now.y]=f[nw.x][nw.y]+t[i].c;
q.push(now);
}
}
}
}
}
struct Line
{
double k,b;
Line() {}
Line(double nk,double nb) {k=nk;b=nb;}
}P[Maxn];int sl;double tt[Maxn]; double pt(double k1,double b1,double k2,double b2)
{
return (b2-b1)/(k1-k2);
} void get_ans()
{
int q=read();int cnt=;
while(q--)
{
int st=read(),ed=read();
for(int i=;i<=n;i++)
for(int j=;j<=n;j++) {f[i][j]=INF;}
dij(st);
bool pp=;
for(int i=;i<=n;i++) if(f[ed][i]!=INF) {pp=;break;}
if(!pp) {printf("0 0\n");continue;}
if(f[ed][]==INF) {printf("inf\n");continue;}
int num=;
LL sum=;sl=;
for(int i=n;i>=;i--)
{
if(f[ed][i]==INF) continue;
while(sl>=&&pt(P[sl].k,P[sl].b,i,f[ed][i])<=tt[sl]) sl--;
P[++sl]=Line(i,f[ed][i]);
if(sl>) tt[sl]=pt(P[sl-].k,P[sl-].b,P[sl].k,P[sl].b);
}
for(int i=;i<=sl-;i++)
{
int l=(int)tt[i]+,r=(int)tt[i+];
if(l<=r) sum+=(LL)(l*P[i].k+P[i].b+r*P[i].k+P[i].b)*(r-l+)/;
}
num=(int)tt[sl];
if(tt[sl]!=num||sl==) num++,sum+=f[ed][];
printf("%d %lld\n",num,sum);
}
} int main()
{
n=read();m=read();
len=;
memset(first,,sizeof(first));
for(int i=;i<=m;i++)
{
int x,y,c;
x=read();y=read();c=read();
ins(x,y,c);
}
get_ans();
return ;
}
【凸包和dij都好弱啊,膜了一下某大神代码。。】
2017-03-31 08:17:57
【BZOJ 3482】 3482: [COCI2013]hiperprostor (dij+凸包)的更多相关文章
- bzoj 1185 [HNOI2007]最小矩形覆盖 凸包+旋转卡壳
题目大意 用最小矩形覆盖平面上所有的点 分析 有一结论:最小矩形中有一条边在凸包的边上,不然可以旋转一个角度让面积变小 简略证明 我们逆时针枚举一条边 用旋转卡壳维护此时最左,最右,最上的点 注意 注 ...
- BZOJ 1069 Luogu P4166 最大土地面积 (凸包)
题目链接: (bzoj)https://www.lydsy.com/JudgeOnline/problem.php?id=1069 (luogu)https://www.luogu.org/probl ...
- 【BZOJ】1027: [JSOI2007]合金(凸包+floyd)
http://www.lydsy.com/JudgeOnline/problem.php?id=1027 题意:$n$种材料,$m$种需求.每种材料有三个属性,给出三个属性的含量(和为1),问能否通过 ...
- bzoj 1209: [HNOI2004]最佳包裹 三维凸包
1209: [HNOI2004]最佳包裹 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 160 Solved: 58[Submit][Status] ...
- BZOJ 2300: [HAOI2011]防线修建( 动态凸包 )
离线然后倒着做就变成了支持加点的动态凸包...用平衡树维护上凸壳...时间复杂度O(NlogN) --------------------------------------------------- ...
- BZOJ [HAOI2011]防线修建(动态凸包)
听说有一种很高端的东西叫动态凸包维护dp就像学一下,不过介于本人还不会动态凸包就去学了下,还是挺神奇的说,维护上下凸包的写法虽然打得有点多不过也只是维护复制黏贴的事情而已罢了. 先说下动态凸包怎么写吧 ...
- BZOJ 3203 [SDOI2013]保护出题人 (凸包+三分)
洛谷传送门 题目大意:太长略 每新加入一个僵尸,容易得到方程$ans[i]=max{\frac{sum_{i}-sum_{j-1}}{s_{i}+d(i-j)}}$ 即从头开始每一段僵尸都需要在规定距 ...
- BZOJ3482 : [COCI2013]hiperprostor
对于每组询问,spfa求出f[i][j]表示从S出发,经过j条x边到达i的最短路. 若f[T][i]都为inf,则无解. 若f[T][0]为inf,则有无穷个解. 否则可以看作若干条直线,$O(n)$ ...
- bzoj 3203: [Sdoi2013]保护出题人 凸包
题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3203 题解 首先我们考虑对一大波僵尸来袭的情况进行分析 假设来袭的僵尸是\(\{ a_1 ...
随机推荐
- 【BZOJ】3771: Triple FTT+生成函数
[题意]给定n个物品,价值为$a_i$,物品价格互不相同,求选一个或两个或三个的价值为x的方案数,输出所有存在的x和对应方案数.$ai<=40000$. [算法]生成函数+FFT [题解]要求价 ...
- 【洛谷 P3705】 [SDOI2017]新生舞会(费用流,01分数规划)
题目链接 看到这题我想到了以前做过的一题,名字记不清了,反正里面有"矩阵"二字,然后是道二分图匹配的题. 经典的行列连边网络流. 第\(i\)行和第\(j\)列连边,费用为\(b[ ...
- 解决ajax chrome禁止本地浏览时加载本地其他文件的方法
在chrome快捷键右键--属性 “ --allow-file-access-from-files ”,前面用空格隔开.然后应用--确定.
- 二叉树的层序遍历(levelordertraverse)
数据结构关于二叉树的遍历还有一种层序遍历,按层次依次输出元素.最上层最先输出,同层中最左最先输出,使用队列这一结构来实现: int levelOrderTraverse(IDTree *pTree) ...
- ProxySQL(MGR)部署故障:'sys.gr_member_routing_candidate_status' doesn't exist
ProxySQL(MGR) 故障排查: 故障现象:runtime_mysql_servers节点状态offline_hostgroup(本案例为15) 日志关键信息: [WARNING] Group ...
- c++环境配置 Eclipse+mingw-get-setup
1,到官网下载eclipse 和 mingw-get-setup 2,先安装eclipse,然后等着... 3,再安装mingw-get-setup, 等待...安装完成后打开,选择basic s ...
- Oracle数据库,基础知识
1.Oracle的五大约束条件: 1 主键 primary key2 外键 foreign key,3 唯一 unique,4 检测 check5 非空 not null 实例运用: -- ...
- Java容器---Arrays & Collections工具类
1.Array & Arrays 与Collection & Collections区别 (1)Collection": 是一个接口,与其子类共同组成一个Collection ...
- 渗透常用SQL注入语句合集
1.判断有无注入点; and 1=1 and 1=2 2.猜表一般的表的名称无非是admin adminuser user pass password 等..and 0<>(select ...
- CentOS6.9下安装MariaDB10.2.11
yum groupinstall -y "Development Tools" yum install -y cmake openssl-devel zlib-devel yum ...